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Дорогой читатель! 

с сегодняшнего дня мы начинаем принимать подписку 
на 1992 год. Бланк заказа помещен в конце этого номера. К 
сожалению^ журнал опять подорожает, немного, но все- 
такиі Причины, наверное, можно не объяснять по мно- 
гочисленным требованиям трудящихся все дорожает. И этот 
процесс^ похоже, необратим, по крайней мере, на 
ближайшие годы. Поэтому нас сегодня больше волнует, как 
не разочаровать читателя, потратившегося на подписку. 

Что же изменится в следующем году? Во-^первых, 
видимо, с обложки исчезнет подзаголовок “Обозрение зару- 
бежной прессы”, поскольку фактически уже давно журнал 
является обозрением не “зарубежной прессы”, а зарубежно- 
го оборудования и программного обеспечения, причем, во 
мнбЬіх случаях статьи пишутся чисто авторские, вообще 
без какой-либо связи с “зарубежной прессой”. 

Во-вторых, мы учтем упрек, высказанный нам читателем 
Иваном Тургеневым: 

Мы за границу ездим, о друзья. 

Как казаки в поход... Нам все не в диво; 

Спешим, чужих презрительно браня. 

Их сведений набраться торопливо... 


То есть в следующем году мы будем больше уделять 
внимания отечественным разработкам и зарубежным про- 
дуктам, продающимся в стране, упорно бредущей по 
социалистическому пути. Действительно, какой смысл 
писать о винограде, ежели его не достать? 

В-третьих, вышеупомянутые продукты будут нами 
тестироваться, а результаты тестирования будут публико- 
ваться в новой рубрике, название которой еще не придума- 
но. Так что, если у кого появится желание сравнить свое 
детище, скажем, с \Ѵіп()о\ѵ$ или с БсапМап 256, — милости 
просим. 
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Сегодня мы публикуем информацию, предоставленную нам 
Евгением Касперским. Важность ее оперативного 
распространения столь высока, что она будет одновременно 
опубликована в газете “СофтМаркет". Кроме того, мы 
разослали ее в сети КЕЕСОМ. Надеемся, что к моменту 
выхода этого номера в свет уже будет готов антивирус. 


Внимание! 
Вирус "Огіѵег-1024" 


Атака очередного компьютерного вируса произошла в 
начале лета 1991 года. Одно из первых сооби^ений о 
заражении этим вирусом пришло из Львова. Оттуда он 
мигрировал в Киев, затем появился в Москве и Ленинграде 
(Санкт-Петербурге). Советские пользователи в основной 
своей массе уже не удивляются появлению вируса в их 
компьютере, однако тут им крупно **повезло** — они 
подверглись нападению вируса совершенно нового типа. 

Основные отличительные черты вируса 

1. Резидентен, поражает СОМ- и ЕХЕ-файлы. Дли- 
на вируса — 1024 байт^. 

2. При инициализации вирус проникает в ядро 
005, изменяет адрес системного драйвера дисков и за- 
тем перехватывает все обращения 008 к этому драй- 
веру. В вирусе реализован мощный стелс-механизм на 
уровне системного драйвера, в результате чего вирус в 
зараженных файлах не виден при чтении файла как 
через іпі 21 Н, так и через іпі 25Н. При этом вирус об- 
ращается напрямую к ресурсам 008 и “пробивает** 
практически любые антивирусные блокировщики. 

3. Поражает логические диски, к которым происхо- 
дит обращение 005. Записывает свое тело в послед- 
ний кластер инфицируемого диска. Этот кластер по- 
мечается как сбойный. 

4. При заражении файлов их длины и содержимое 
кластеров, содержащих эти файлы, не изменяются. 
Вирус корректирует лишь номер первого кластера 
файла, расположенный в соответствующем секторе ка- 
талога. Новый начальный кластер файла будет указы- 
вать на кластер, содержащий тело вируса. Таким об- 
разом, на все зараженные файлы на одном логическом 
диске будет одна копия вируса! 

5. Стремительно распространяется — поражает 
файлы при обращении 008 к секторам, содержащим 
каталоги. Например, при попытке запуска несущест- 
вующего файла 005 будет искать его во всех катало- 
гах, отмеченных в РАТН. При этом вирус перехваты- 


вает обращения 008 к каталогам и заражает файлы 
во всех каталогах, указанных в РАТН. При первом 
старте вирус поражает все файлы текущего каталога 
диска С:. 

Очень высокая скорость распространения, “невиди- 
мость** в файлах и, откровенно говоря, неготовность 
резидентных и нерезидентных антивирусных программ 
к появлению вируса такого класса делают этот вирус 
ОЧЕНЬ опасным! 

ОБНАРУЖЕНИЕ И ЛЕЧЕНИЕ 

Обнаружение в памяти 

Вирус содержит характерные участки кода, по кото- 
рым можно произвести его поиск в оперативной памя- 
ти (участки кода приведены ниже). Поиск нужно про- 
изводить в самом первом блоке памяти. 

Квалифицированный пользователь может пользо- 
ваться другим способом: пройти список Огіѵе 

Рагатеіег Віоск (адрес первого ОРВ возвращается в 
таблице Узі о^ Узі при вызове іпі 21 Н, !.52) и искать 
драйверы, начинающиеся с адреса ХХХХ:04Е9. По ад- 
ресу ХХХХ:0100 будет располагаться начало вируса. 
Следует учитывать, что при прохождении списка заго- 
ловков драйверов вирус не будет обнаружен, так как 
он меняет лишь адрес драйвера в соответствующей 
ОРВ и не меняет коды и данные системных драйверов. 

Обнаружение и лечение на диске 

Для обнаружения вируса на диске лучше загрузить- 
ся с заведомо чистой от вирусов заклеенной дискеты, 
содержащей 008 и утилиты типа погіоп Оізк Оосіог и 
Могіоп Оізк ЕсШог. При тестировании диска N00 со- 
общит о том, что большое число файлов имеют общие 
участки (СК088-иЫКЕО), а последний кластер дис- 
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ка — сбойный. Этот сбойный кластер должен содер- 
жать тело вируса. 

Лечение довольно просто производится при рези- 
дентном вирусе (то есть когда вирус инфицировал 
оперативную память). При этом достаточно 
переименовать все СОМ- и ЕХЕ-файлы в файлы с 
другими расширениями имени (например, в ССС- и 
ЕЕЕ-файлы) или заархивировать их. Затем следует 
загрузиться с заведомо чистой от вирусов заклеенной 
дискеты и переименовать файлы обратно (или 
разархивировать их). 

Если память компьютера не заражена вирусом, то 
лечение файлов является довольно непростой процеду- 
рой. Поэтому такие файлы лучше уничтожить. 


Характерные участки вируса 


0100 

ВС 00 06 

МОѴ 

8Р,600Н 

0103 

ГГ 06 ЕВ 04 

ШС 

[04ЕВ] 

0107 

31 С9 

ХОК 

сх,сх 

0109 

8Е П9 

МОѴ 

08,СХ 

010В 

С5 06 С1 00 

Ь08 

АХ,0\ѴОКО РТК 

П8:[00СЦ 




; 8ТКАТЕСѴ — > С8:024В 


024В 

50 

Р08Н 

АХ 

024С 

51 

Ри8Н 

СХ 

0240 

52 

Ри8Н 

ОХ 

024Е 

1Е 

Р08Н 

08 

024Г 

56 

Р08Н 

81 

0250 

57 

ри8н 

ОІ 

0251 

06 

Р08Н 

Е8 

0252 

1Г 

РОР 

08 

0253 

8А 47 02 

МОѴ 

АЬ,[ВХ + 21 

; ІКТЕККОРТ — 

> 

С8:02А2 

02А2 

СВ 

КЕТГ 


; ѴШ08 ОЕѴІСЕ НЕАОЕК 

— > 

С8:04Е9 

04Е9 

40 

INС 

АХ 

04ЕА 

СЗ 

КЕТN 


04ЕВ 

хххх 

0\Ѵ 

ххН 

04ЕО 

0842 Оеѵ_АПг 

0\Ѵ 

842Н 

04ЕГ 

024В Оеѵ_8ігаіе^ 

о>ѵ 

ОРГ8ЕТ 8ТКАТЕСѴ 

04Г1 

02А2 Оеѵ_ітггирІ 

О^Ѵ 

ОРГ8ЕТ INТЕКК^РТ 


ЕЖасперский 
109028 Москва, Тессинский пер., дом 6/19 
Акционерное оби^ество **КАМИ** 
Научно-производственный отдел 
телефон (8-095) 499-15-00 


ЬоШз Оеѵеіортеп! Согр. и ТНе 
8ап1а Сгиг Орегабоп Іпс. (8СО) 
пришли к согласию в судебном 
иске ІюШз против 8СО. Догово- 
рившиеся между собой, стороны 
решили, что Ьоіиз снимает все 
свои судебные претензии к 8СО, 
а последняя перестает произво- 
дить и продавать свою програм- 
му работы с электронными таб- 
лицами 8СО РгоГеззіопаІ. 

8СО также будет рекомендо- 
вать всем пользователям, уже 
купившим 8СО РгоГеззіопаІ, пе- 
рейти на Іюіиз 1-2-3 Гог ІІЫІХ 
8узіет V, который поддерживает 
8СО иМІХ 8уз1ет Ѵ/386, 8СО 
Орел Оезкіор и 8СО ХЕЫІХ 386. 
Чтобы поддержать эту рекомен- 
дацию, Ьоіиз будет продавать 
этот пакет со скидкой для поль- 
зователей 8апіа Сгих — всего за 
395 долларов. 

Фирма Вогіапб Іпіегпаііопаі, 
чья программа работы с табли- 


цами риаПго Рго была также 
указана среди нарушителей ав- 
торского права в судебном иске 
Ьоіиз, прокомментировала собы- 
тие так: “Решение спора между 
8СО и Ьоіиз не окажет никакого 
влияния на наш судебный про- 
цесс. Хотя мы и не можем пред- 
сказать его результаты, компа- 
ния продолжает настаивать на 
том, что риайго Рго является 
оригинальным продуктом и не 
нарушает никаких авторских 
прав на 1-2-3“. 

Ричард Шаффер, руководи- 
тель фирмы ТесЬпоІо^іс 
Рагіпегз, отйетил следующее: “Я 
не думаю, что 8СО испытывает 
сильное желание защищать свою 
табличную программу. Ее основ- 
ной заботой является появление 
большего числа качественных 
прикладных программ, которые 
работают под 8СО Ііпіх. Поэто- 
му, если Ьоіиз действительно 


серьезно отнесется к своим обя- 
зательствам, исход процесса бу- 
дет выгоден обеим сторонам. Хо- 
тя Вогіапсі и остается единствен- 
ным противником Еоіиз в этом 
деле, его позиции остаются не- 
изменными“. 

Финансовый аналитик, посто- 
янно отслеживающий деятель- 
ность фирмы Еоіиз, сказал, что 
по его мнению процесс скоро 
получит новый толчок — 
Вогіапсі подала протест, заявляя, 
что фирма не имеет права 
требовать защиты авторских 
прав отдельно на систему меню 
пакета 1-2-3. “Отделение меню 
от остального продукта может 
иметь смысл в патентном про- 
цессе, а не при рассмотрении 
авторских прав“. 

Ме\ѵ8ЬуІе8 Ме\98 Меімюгк, 
18 /иіу, 1991 
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Все три сверхдержавы никогда не 
предпринимают маневров, чреватых 
риском тяжелого поражения. Если и 
осуществляется крупная операция, то, 
как правило, это внезапное нападение на 
союзника... Отсюда следует, что три 
державы не только не могут покорить 
одна другую, но и не получили бы от 
этого никакой выгоды. Напротив, 
покуда они враждуют, они подпирают 
друг друга подобно трем снопам. 

Джордж Оруэлл, “1984“, гл. IX 


НОВЕЙШАЯ ИСТОРИЯ 
КОМПЬЮТЕРНЫХ ВОИН: 

кошмары по Оруэллу 


С апреля этого года читатели массовой прессы вы- 
нуждены осваивать язык арифметических выражений. 
“9+1“, “15+0“, “9+6+Х“. Следуя этому стилю, апрель- 
скую новость, о которой вам рассказал Компьютер- 
Пресс №5, можно записать с помощью оператора при- 
сваивания АСЕ = 3+17. Среди трех лидеров компью- 
терного мира, возглавивших работы по стратегической 
программе АСЕ, — фирма МісгозоП. С тех пор 
минуло всего лишь три месяца, и вот... 

Посещают ли кошмары сон Билла Гейтса? Недавно 
он сам признался — посещают. И даже рассказал, ка- 
кие. “И вот снится мне, что ІВМ нас атакует с си- 
стемного фланга, Ноѵеіі — с локально-сетевого, а лю- 
бители оконных интерфейсов с лозунгом на стяге 
ОКОШКИ НАШИ ЛУЧШЕ ВАШИХ объединились и 
напирают по всему фронту. А самое кошмарное — то, 
что это так и есть“. 

Смягчить впечатление от сказанного Гейтсом на 
июньской оперативке администрации фирмы МісгозоП 
попытался его коллега Стив Болмер. Он философски 
заметил, что удел бизнесмена — всегда быть готовым 
к худшему. В том числе и к падению биржевого курса 
акций фирмы в конце июня. И к печальному для Мі- 
сгозоП развитию событий в расследовании, проводи- 
мом Федеральной комиссией по делам торговли, кото- 
рая интересуется возможными нарушениями антимо- 
нопольного законодательства со стороны МісгозоП. Да 


еще Фирма Арріе Сотриіег через своих адвокатов не- 
тактично “подбрасывает** вопрос о правах МісгозоП на 
применение в своих продуктах метафоры оконного ин- 
терфейса. 

Все эти, говоря военно-полевым языком, вводные 
обрушились на фирму МісгозоП не вчера. И ответные 
действия ее показали, что с порохом в пороховницах 
проблем нет. Апрельское коммюнике группы фирм, 
объявивших о развертывании стратегической про- 
граммы АСЕ (см. КомпьютерПресс №5 за этот год), 
свидетельствует о присущем членам этого альянса чув- 
стве перспективы. Действительно, объединить в общей 
операционной среде функции М8 005, 08/2, 

М8 АѴіпсІоіѵз и ядра Р05ІХ для массовых 
персональных компьютеров начала 90-х годов — цель 
прагматичная и отвечающая сложившемуся у 
пользователей имиджу фирмы Гейтса. Мол, Гейтс — 
это опытный сталкер, который выведет в опасной зоне 
каждого клиента к причитающемуся оному клиенту 
счастью. Счастье может прийти нежданно, если не 
боишься рискнуть, — и КІЗСуют, отправившись за 
Гейтсом со товарищи в зону, где их ждут рабочие 
станции с микропроцессором МІР5 К4000 внутри. 

А тем временем **синий гигант** решил, что ему не 
помешают лавры Синей Бороды. Многолетний брак 
фирм 1ВМ и МісгозоП, принесший миру обильное по- 
томство, оказался перед перспективой стремительного 
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НОВЕЙШАЯ ИСТОРИЯ КОМПЬЮТЕРНЫХ ВОЙН: КОШМАРЫ ПО ОРУЭЛЛУ 


разрыва отношений. Кого выберет в партнеры ІВМ? 
Оказалось, что в амурах этому персонажу нет равных: 
такого никто не ожидал. Новый альянс свел под вен- 
цом таких конкурентов, для которых любое другое 
партнерство было бы лишь скучной регистрацией лег- 
кой победы. Мало ли фирм и фирмочек побывало в 
доме ІВМ на правах ветреных служанок... Здесь же 
все серьезно: фирма Арріе Сотриіег вступает в закон- 
ный брак с ІВМ, и уже имя первенцу придумали. 
“Совместно созданная и независимо функциониру- 
ющая фирма для разработки мобильных объектно-ори- 
ентированных программных средств**. Длинновато, но 
запоминается. 

Итак, 3 июля этого богатого событиями года фирмы 
ІВМ Согрогаііоп и Арріе Сотриіег Іпс. подписали про- 
токол о намерениях, обусловленный заключением в 
ближайшее время конкретных соглашений. Среди на- 
меченных направлений работ — поставка програм- 
мных средств, создаваемых совместным предприятием 
ІВМ-АррІе, на рынок персональных компьютеров (в 
том числе и для **третьих поставщиков**). Какие же 
платформы будут годиться для этих мобильных про- 
грамм? Любые, если они содержат архитектурное ядро 
**Х86 ИЛИ 680X0 ИЛИ КІ8С РОАѴЕК**. О последнем 
терме в этом выражении надо сказать отдельно. КІ8С- 
процессор, разработанный инженерами ІВМ для мощ- 
ных рабочих станций, дороговат для массовых ком- 
пьютеров. И это обстоятельство заставило фирму ІВМ 
сделать еще один важный шаг — альянс становится с 
самого начала тройственным. Фирма Моіогоіа, у кото- 
рой есть давний опыт сотрудничества с ІВМ (вместе 
пытались разместить в наборе БИС архитектуру ІВМ 
8уз1ет/370), вместе с ІВМ выпустит скоро дешевую 
версию БИС для архитектурного ядра РО>ѴЕК. На 
судьбе родного детища Моіогоіа 88000 этот выбор мо- 
жет сказаться роковым образом. 

Выбор весьма популярной сегодня объектно-ориен- 
тированной технологии программирования в качестве 
общей идеологии также выглядит естественным. ІВМ 
получает доступ к богатому опыту Арріе в этой обла- 
сти, и вместе они намерены доработать систему АІХ 
таким образом, чтобы в ней поддерживались графи- 
ческие пользовательские интерфейсы МасіпіозН и 
ОЗР/МоІіІ. Конечная цель здесь — добиться, чтобы 
прикладные программы для трех операционных систем 
предыдущего поколения — 08/2 (теперь это прием- 
ный ребенок ІВМ?..), АІХ и Зузіеш 7.0 МасіпІозН — 
работали в общей операционной среде. 

Встречный интерес фирмы Арріе направлен прежде 
всего к опыту ІВМ в области сетевых архитектур. 
Здесь брезжит решение ключевой для Арріе проблемы: 
доступа к крупным заказам на комплексную автомати- 
зацию предприятий, где часто побеждало стремление 
заказчика иметь дело с одним поставщиком по спек- 
тру от больших машин до терминалов. Интересно 
вспомнить, что альянс на эту же тему был оформлен 
всего пару лет назад между Арріе и Оі^ііаі. Какая его 
ждет теперь судьба? 


Наконец, особо оговорено, что Арріе и ІВМ отдадут 
высокий приоритет совместным разработкам в области 
информационной технологии МиШтебіа. 

На развертывание всех упомянутых выше работ 
фирмы дали своим инженерам не более двух-трех лет. 

В интервью корреспонденту информационного 
агентства НЕАѴ8ВУТЕ8 представительница Арріе Бар- 
бара Краузе заявила: **Это соглашение позволит нам 
продвинуться в достижении трех важных целей. 
Во-первых, мы наконец всерьез приступим к развитию 
КІ8С-платформы для ряда моделей МасіпІозН. 
Во-вторых, приобретение имиджа в ЯІ8С-технологии 
поможет нам продвинуться на рынок больших корпо- 
раций, к чему мы всегда стремились. В-третьих, ин- 
теграция с высокопроизводительными компьютерами 
была и остается для нас ключевой проблемой**. 

Пока что слухи о кандидатуре руководителя для со- 
здаваемого совместного предприятия ІВМ-АррІе Краузе 
ни подтвердила, ни опровергла. Им может стать Дей- 
вид Лиддл — глава динамичной молодой фирмы 
МеіарНог Бузіетз. 

Наши цели ясны, задачи определены — за работу, 
господа? Нас ожидает борьба двух действительно мо- 
гучих триумвиратов — ІВМ/Арр1е/Мо1ого1а и Мі- 
сгозоП/Сотра^/^І 5 иа 1 в наиболее сложном секторе 
компьютерного рынка. И хотя ни один из шести парт- 
неров не может быть заподозрен в желании таскать из 
огня каштаны для кого-то еще, в ожидании жареных 
каштанов уютно устроились две сторонящиеся этих 
игр фирмы. Это — всего-навсего АТ&Т и Іпіеі. 

В эти жаркие июльские дни усталый вздох вырвался 
из груди ветерана компьютерной журналистики 
Джона МакКормика (агентство МЕ\Ѵ5ВУТЕ8): 
**Теперь можно и на пенсию... Могу смело сказать — 
в этой индустрии я повидал все, что только может 
случиться.** 

А случаи — что апрельский, что июльский — и 
впрямь судьбоносные. Джордж Оруэлл не отказался бы 
включить эти сюжеты в продолжение своего “Тысяча 
девятьсот восемьдесят четвертого**: сверхдержавы мол- 
ниеносно перестраивают на карте мира свои боевые 
колонны, а идеологи находят этому единственно вер- 
ное обоснование. Враги? Союзники? Все это прехо- 
дяще, и вообще, ведь именно программисты первые 
отметили, что любая константа — всего лишь очень 
медленно изменяющаяся переменная... “Пожалуй, 
скоро герою войны в Заливе генералу Шварцкопфу 
предложат должность председателя правления в ком- 
пьютерной фирме, где исполнительным директором — 
Дейвид Лиддл**, — комментирует происходящее Джон 
МакКормик. 

А.Гиглавый (Лицей информа- 
ционных технологий), 

К.Чащин (московское отделе- 
ние информационного 
агентства МЕАѴ5ВУТЕ8) 
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Суета вокруг Роберта 
или Моррис-сын 
и все, все, все... 


...Компьютерный мир развивался. И вот в 1969 году в 
США появилась глобальная сеть Аграпеі, соединившая ты- 
сячи компьютеров и огромное количество пользователей. 
Возможность работы с коллегой, находяищмся за тысячу 
километров, привлекла многих. В сети работали сотрудни- 
ки и студенты унивеситетов и колледжей, подрядчики 
Пентагона. В том же 1969 году появилась на свет опера- 
ционная система ѴЫ1Х, быстро завоевавшая широкую по- 
пулярность. И, казалось, ничто не предвещало бури... 

Итак, 1988 год. Лето. В АТ&Т Веіі ЬаЬогаІогіез рабо- 
тает студент выпускного курса одного из университетов. 
Он занимается программами обеспечения безопасности 
ѴЫ1Х. Зовут молодого человека Роберт Моррис. 

2 ноября 1988 года. Вечером в разных концах страны на 
компьютерах, работаюищх под І1ЫІХ, был обнаружен ви- 
рус. Постепенно выяснилось, что вирус одинаков на всех по- 
раженных машинах. В результате его работы загрузка сис- 
тем повышалась, а после достижения ею критического 
уровня системы переставали работать. 

Вирус распространялся с поразительной скоростью и 
появлялся в разных концах страны. Был сделан вывод, что 
вирус распространяется через сеть. Через 5 часов было по- 
ражено около 800 систем, через двое суток — 6000. 

Атака велась на самые популярные сети, в том числе 
пентагоновские, и на самую популярную операционную сис- 
тему. К мероприятиям по обезвреживанию вируса подклю- 
чились представители ФБР. Уже 4 ноября они нашли фай- 
лы, использованные при создании вируса. Их владельцем 
оказался Роберт Таппан Моррис. В тот же день он явился 
с повинной в штаб-квартиру ФБР в Вашингтоне... 


Что за этим последовало 


Всхгкресенье, 6 ноября 1988 года. 

15:50 КІ5К5 Высказаны предупреждения против раз- 
дувания большей шумихи вокруг вируса, чем это 
сделано в прессе. Событие, “происшедшее в действи- 
тельности, не является сюрпризом ни для читателей 
КІ5К8, ни для пользователей Іпіегпеі или 


Окончание. Начало см. КомпьютерПресс №8, 1991. 


19:01 К18К8 Краткое обращение к пользователям с 
призывом изучать вирус; отмечается, что “неэтич- 
ность и другие злоупотребления не являются необыч- 
ными“. Компьютерные системы должны перестать 
быть “относительно широко открытыми**. 

Понедельник, 7 ноября 1988 года. 

15:44 КІ8К8 Обсуждение возможности провокации 
вирусом ядерной войны. Вызвано воскресным сооб- 
щением (15:50), но впадает в противоположную 
крайность, преувеличивая возможность “ядерного 
Армагеддона**. 

19:06 ѴІК. Частная реакция на вирус Іпіегпеі ком- 
пьютерной службы, которая “непосредственно даже 
не связана с Іпіегпеі** и лишь к этому моменту была 
оповещена из местных газет и местных филиалов 
АВС и МВС. 

8 ноября 1988 года в Вашингтоне была организова- 
на встреча группы программистов и экспертов по ком- 
пьютерной безопасности из различных университетов 
с одной стороны и представителей федеральных влас- 
тей с другой — “Ргосеесііп^ оГ ІНе Ѵігиз Розі-Могіет 
Мееііп^**. 

Целью встречи было обсуждение результатов вирус- 
ной атаки и сложившейся в связи с этим ситуации и 
выработка предложений относительно того, как избе- 
жать повторения подобных атак в будущем. На встре- 
че был принят документ, состоящий из 1 1 рекоменда- 
ций участников совещания. 

Одним из результатов встречи стал запрос МС8С к 
исследователям университета в Пурду на удаление из 
компьютерной системы университета всей информа- 
ции, касающейся алгоритма работы вируса. Универси- 
тет удалил всю информацию, которая, с точки зрения 
специалистов, представляла какую-либо опасность. 

Согласно рекомендациям была создана так называе- 
мая Группа ответа на компьютерную опасность 
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СУЕТА ВОКРУГ РОБЕРТА ИЛИ МОРРИС-СЫН И ВСЕ. ВСЕ. ВСЕ,.. 


(Сотриіег Етег^епсу Кезропзс Тсат). В настоящее “внутренней работе программ, которые осложняют ра- 
время группа ответа официально располагается в уни- боту американских компьютеров^. 

РЕКОМЕНДАЦИИ СОВЕЩАНИЯ, СОСТОЯВШЕГОСЯ 8 НОЯБРЯ 1988 ГОДА 

I. Образовать единый координационный VII. Определить центральное место размеще- 


центр на случай подобных атак. 

Центр должен работать совместно с КІ8Т и 
Н8А, выполняя функции обобщения данных 
и определения ущерба. 

II. Образовать сеть аварийного оповещения. 
Такой аварийной сетью связи может служить 
совокупность специальных телефонных ли- 
ний, которая сможет заменить компьютер- 
ную сеть в случае выхода последней из строя 
по каким-либо причинам. 

III. Создать группу ответа. 

Члены группы должны иметь целью быстрое 
дезассемблирование вируса, создание антиви- 
руса и выработку плана восстановления сети. 

IV. Образовать физическую связь с "сетью 
стариков" <оЫ Ьоу (зіс) пеімгогк> — признан- 
ных авторитетов в области информатики и 
вычислительной техники. 

Это является косвенным признанием того, 
что вирус Морриса был дезассемблирован и 
уничтожен не правительственными чиновни- 
ками, а специалистами-компьютерщиками. 

V. Централизованно управлять предоставле- 
нием информации прессе. 

Связь с прессой — единственная обязанность 
правительственных органов национального 
уровня. 

VI. Определить стандартную процедуру реак- 
ции на "промышленные промахи." 

Данная атака выявила целый ряд ошибок в 
системном программном обеспечении, однако 
на данный момент не существует общеприз- 
нанного метода доказательства "промышлен- 
ного" характера этих ошибок. 


верситете Карнеги-Меллона. находясь на финансовом 
обеспечении серьезно обеспокоенного инцидентом 
Пентагона. 

ФБР наложило запрет на все материалы, имеющие 
отношение к вирусу Морриса, а 11 ноября 1988 года в 
“Нью-Йорк Таймс“ в статье Джона Маркоффа было 
заявлено, что МС8С ищет способы, чтобы вообще ос- 
тановить распространение точной информации о 


ния сообщении о вирусных атаках. 

Эти функции может выполнять ЕВВ Воск- 
тавіег правительственной компьютерной 
сети. 

VIII. Подключать следственные органы уже 
на этапе планирования и проведения меро- 
приятий борьбы с вирусной атакой. 

Это позволит следственным органам своевре- 
менно фиксировать информацию, которая 
впоследствии будет служить основой для рас- 
следования и формулировки обвинений. 

IX. Постоянно тренировать операторов сис- 
тем. 

Вирусная атака показала, что многие опера- 
торы не имеют достаточных технических 
знаний и практических навыков даже для 
понимания, что их система атакована. Они 
также с трудом обращаются с антивирусны- 
ми средствами. 

X. Установить стандартную методологию 
Ьаскир-копирования. 

Существующая система "зеркального" копи- 
рования потерпела крах при испытании ви- 
русной атакой, поэтому должны быть разра- 
ботаны новые стандарты и критерии копиро- 
вания, информация о которых должна рас- 
пространяться КІ8Т и N080. 

XI. Развивать набор общих антивирусных 
средств, включая средства дезассемблирова- 
ния и анализа. 

Этот набор общих средств необходимо пос- 
тоянно пополнять и поддерживать в работо- 
способном состоянии, а также необходимо 
обеспечить надежный и быстрый доступ к 
этому набору членов группы ответа. 


Теперь, я думаю, вам стало понятно, почему 
получить подробные материалы (и по вирусу Морриса, 
в частности) в настоящее время не так-то просто. 

Вирусная атака послужила причиной резко возрос- 
шего интереса к средствам обеспечения безопасности 
как вычислительных систем, так и объединяющих эти 
системы сетей. 
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правительственные лаборатории и исследовательс- 
кие центры, занимающиеся проблемами защиты ин- 
формации, интенсифицировали работы над созданием 
сложных и, по возможности, универсальных антиви- 
русных программ, которые должны выявлять и блоки- 
ровать вирус на самых ранних стадиях его развития. 
Однако, по мнению экспертов, если такие программы 
и удастся создать, они вряд ли станут достоянием 
гласности и, вероятнее всего, в случае создания уни- 
версальных антивирусных программ они будут рас- 
сматриваться как своего рода “стратегическое ору- 
жие“. 

К работам по борьбе с вирусами и созданию “им- 
мунных“ прогоамм подключились Национальный 
научный фонд США, биржа Уолл-Стрита и др. Беспо- 
койство финансовых кругов США объясняется их 
сильной зависимостью от вычислительной техники, на 
базе которой функционирует вся система электронных 
безналичных расчетов. 

Промышленная ассоциа- 
ция по компьютерным виру- 
сам только за 1988 год за- 
фиксировала почти 90 тысяч 
вирусных атак на персональ- 
ные компьютеры, а по дан- 
ным Национального центра 
информации по компьютер- 
ной преступности (КаНопаІ 
Сепіег (ог Сошриіег Сгііпе 
Паіа), за этот же год ком- 
пьютерная преступность на- 
несла американским фирмам 
убытки в размере 500 млн. 
долларов. В наи^льшей сте- 
пени от этого страдают бан- 
ки. По словам Ховарда Глас- 
смана, который отвечает за 
безопасность в Вапк о1 Ашегі- 
са, компьютерная преступ- 
ность может стать причиной 
крушения экономической 
системы страны. 

На самом деле, количество 
инцидентов, связанных с ви- 
русами, вероятно, превосхо- 
дит опубликованные цифры, 
поскольку большинство фирм 
умалчивает о вирусных ата- 
ках, опасаясь, что подобная 
“реклама" повредит их репу- 
тации. Другие фирмы мол- 
чат, чтобы не привлекать 
внимание хакеров. Как заме- 
тил администратор фирмы 
Аш\ѵау, “лучший способ из- 
бежать проблем с вируса- 
ми — не болтать о том, что 
вы предпринимаете во избе- 
жание этих проблем". 

Поскольку вирус Морриса ощутимо ударил по репу- 
тации одного из популярнейших семейств операцион- 
ных систем — ІІЫІХ, совсем неудивительно, что раз- 
работчики стали прилагать лихорадочные усилия вос- 
становления былого авторитета своего детища и соот- 
ветственно для удержания рынка сбыта. 


Так, специалистов калифорнийс- 
кого университета в Беркли — мес-. 
та рождения ІІЫІХ Вегкеіеу — ви- 
русная атака побудила заново пол- 
ностью проанализировать свою сис- 
тему, исправить обнаруженные чер- 
вем дыры и отключить в системе 
ІІЫІХ режим отладки. Они также переписали прог- 
рамму Ріп^ег, научив ее проверять границы размещае- 
мой ею памяти с тем, чтобы любой проникший в сис- 
тему вирус не смог бы записать в эту память свои 
коды. 

Как сообщил в феврале 1989 года вице-президент 
компании АТ&Т Вильям О'Ши ОѴіИіат О'ЗНеа), для 
системы ІІЫІХ 4.1 были разработаны улучшенные 
средства обеспечения безопасности. Новшества состоя- 
ли в усовершенствовании методологии доступа, обес- 
печении целостности дан- 
ных, отказе от утилит и 
проведении ненавязчивой 
политики сдерживания. 
Существовавший ранее 
статус суперпользователя 
заменен статусом супер- 
пользователя, который ра- 
ботает только в период 
установки системы. Без- 
опасность паролей улуч- 
шена за счет применения 
“теневых“ файлов паро- 
лей. Использованы меха- 
низмы ограничения досту- 
па к файлам в соответст- 
вии с текущей формой 
активности в системе. 
Реализована более гибкая 
система авторизации, 
включающая групповые и 
пользовательские иденти- 
фикаторы, а такя^е конт- 
роль команд и процедур 
входа. 

Не остались в стороне 
и владельцы националь- 
ных компьютерных сетей, 
в частности Іпіегпеі. Іп- 
Іегпеі АсІіѵШез Воагб (ко- 
митет ІпІегпеО в феврале 
1989 года заявил о наме- 
рении ввести с целью уве- 
личения сохранности 
сообщений электронной почты в Іпіегпеі новый 
стандарт безопасности. Пользователи получат 
возможность шифровать свои сообщения, а также 
проверять идентичность отправленного и полученного 
сообщений. Стандарт безопасности включает ОЕ8, 
систему аутентификации из К8А Оаіа Зесигііу и 
формат аутентификации ССІТТ Х.509. 




2 Зак. 2399 
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СУЕТА ВОКРУГ РОБЕРТА ИЛИ МОРРИС-СЫН И ВСЕ, ВСЕ, ВСЕ- 


ПАРОЛИ, ОПРОБОВАННЫЕ ВИРУСОМ МОРРИСА 


ааа асоиіетіа аегоЫсв аігрІапеаІЬапу аІЬегі аіех аіехаікіег аІуеЬга аііавея 

аІрНаЬеі ата атогрНоив апаіое апсНог ашіготгшсНе апітаів апзшег 

апіНгороуепіс апѵіів апиікіпе агіа агииіпе аггоіѵ агіНиг аіНепа аітоарНеге 

агиге ЫіссНив Ьаііеу Ьапапа Ъапапая ЬаП(Ш Ьапкз ЬагЬег Ьагііопе 

Ъал» Ьаввооп Ьаітап Ьеаіег Ьеаиіу ЬееіНоѵеп Ьеіоѵей Ъепг Ьеоиюі^ 

Ъегкеіеу ЬегИпег Ьегуі Ьеѵегіу Ысатегаі ЬоЬ Ьгегкіа Ьгіап Ьг'иібеі 

Ьгошішау ЪитЫіп^ Ьиг^евв сауег сатрапііе сапіог саЫіпаІ сагтеп сагоИпе 

савііе савсайез саі сауи^а сеііісв сепііеап сНап^е сНагтіпу сНагІев 

сНагоп сНевіег сіуаг сіаввів соііе^ сотриіег сопдр соокіе согпеііив 

соивсоив сгеаііоп сгеовоіе сгеііп ^аетоп <іапсег (іапіеі сіаппу <іаѵе 

ёесетЬег (іе/ое беіиее (іеврегаіе <іеѵеІор йіеіег йіё'иаі (іівсоѵегу (іівпеу 

(іо^ бгоиуНі йипсап еа^ег еавіег ей^ев еёіпЬигйк ей^ев еёшіп 

е<ііѵіпа е^^Неай еійег^іѵп еііееп еіпвіеіп еІерНапі еІігаЬеіп еііеп етегаШ 

епбіпе епуіпеег епіегргіве епгуте егваіг евіаЫівН евіаіе еисіиі еѵеіуп 

ехіепвіоп іаігшау иЫс’ш ипаег ^гтаі ^ШШу ^іпііе ^івкегв ^Іакев 

Ііоаі ^Іошег ^Іоіѵегв /ооіргоо^ ^ооіЬаІІ іогеві^Ні ^огтаі іогвуіНе /оигіег 

ІгеЛ ^гіеші М^кіеп ^ип ^ипуіЫе уаЬгіеІ ^агЛпег ^агііеЫ уаивв 

беогуе ^егігшіе йіп^ег еіасіег йпи боі^г еоиее йгаНат йиеві 

^ііаг ^піів па^ег Натіеі патиіііу каррепіпб пагтопу Нагоіа пагѵеу 

НеЬгШв Неіпіеіп Неііо Неір кегЬеП НіаіѵаіНа НіЬегпіа Нопеу Ногве 

Ногив НиісНіпв ітЬгоуІіо ітрегіаі іпегев іппа іппосиоив ігівНтап 

і$ів }арап іеввіса іевіег пхіап іопппу іоверк ]овкиа }иёіік 

)иууІе ]іиіа каікіееп кегтіі кегпеі кігкіаші кпібкі Ісиііе ІатЬйа 

Іатіпаііоп Іагкіп Іаггу Іагагив ІеЬевдие Іее Іеіагкі Іегоу Іеіѵів 

Ііукі Ііва Іоиів Іуппе тасіпіовк таек тад^оі тайіс таісоіт 

тагк тагкив тагіу тагѵіп тагіу тавіег таигіее теГіоп тегііп 

теів тіекаеі тіскеііе тіке тіпітит тіпвку тпоёиів тоове тогіеу 

тогагі пароіеоп певв пеііѵогк пеіѵіоп пехі похіоив пиігШоп пудиіві 

осеапо^гарку осеіоі оііѵеііі оііѵіа огасіе огса опѵеіі овігів ^ оиііаіѵ 

ох(оЫ расіііс раіпіевв раківіап рат рарегв раввшоЫ раігісіа реогіа 

репбиіп регсоіаіе регвіттоп регвопа реіе реіег ркШр ркоепіх ріегге 

рігга ріоѵег ріутоиік роіупотіаі ропЛегіпё рогк ровіег ргаіве ргесіоив 

ргеіийе ргіпсе ргіпсеіоп ргоіесі ргоіогоа ритркіп ригіееі рирреі гаЬЫі 

гасктпапіпои гаіпЬоіѵ гаішігор гаіеі^к гагиіот гавсаі геаііи геЬесса гетоіе 

гіек гірріе гоЬоіісв госкевіег гоіех готапо гопаЫ говеЬид, говетагу 

говев гиоеп гиіев гиік ваі вахоп всатрег вскете всоП 

всоііу весгеі вкагкв вкиіііе вібпаіиге вітоп вітріе віп^ег вЫ^Іе 

втііе втііев втооск втоікег впаіск впоору воар восгаіев воввіпа 

враггоіѵв вріі вргіпе вргт^ег вдиігев вігапбіе вШ^огй віиіібагі виЪіѵау 

виссевв виттег вирег вирегвіауе виррогі виррогіеб витіег вигаппе віѵеагег 

вуттеігу іап^егіпе іаре іаг^еі іагга^оп іауіог іеіеркопе іетріаііоп ікаіШпхІ 

іі^ег іоууіе іотаіо іоро^гарку іогіоіве іоуоіа ігаіів іготЪопе ігіѵіаі 

іиЬав іиіііе итевк ипкарру ипісогп ипкпоіѵп игскіп иііШу ѵавапі 

ѵегНбо ѵіеку ѵіііабе ѵіг^іпіа іѵаттеп шаіег іѵеепіе іѵЬліпоі іикШпу 

іѵкііпеу іѵііі шііііат хѵійіатвЬиг^ шИіе іѵіпвіоп іѵівсопвіп іѵігаг(і іѵотЬаі 

уеііоіѵвіопе уоветііе гар 



КОЛЛЕГА! 

При выборе своего пароля избегай использования имен жены или любовни- 
цы и вообще имен, не используй названия городов, стран и вообще назва- 
ний! Для тех, кто не в состоянии придумать сам какую-нибудь абракадабру, 
советую при выборе пароля хотя бы сверяться с приведенным списком, что- 
бы не уподобляться десятому слову четвертого столбца таблицы. 



Защищать сети гораздо сложнее, чем системы. Так, 
например, в Іпіегпеі защите подлежат три основных 
точки: индивидуальные терминалы, локальные сети и 
собственно сеть Іпіегпеі, которая может быть пораже- 
на из любой сети, из числа объединяемых ею. Боль- 
шое значение в связи с этим, помимо аппаратно-прог- 
раммных средств, приобретают организационные ме- 
ры, предпринимаемые в целях обеспечения безопас- 
ности сети вплоть до контроля за дисциплинирован- 
ностью каждого пользователя. 

Для защиты Іпіегпеі специалистами, в частности, 
было предложено следующее: 

- должна быть сформирована политика безопасности 


сети, включая вопросы уголовного преследования на- 
рушителей; 

- операторы Іпіегпеі должны начинать уголовное прес- 
ледование всех лиц, замешанных в атаке сети; 

- операторы Іпіегпеі должны начать регулярные тре- 
нировки с упором на обеспечение безопасности сети; 

- Іпіегпеі должна оплачивать информацию, помогаю- 
щую обнаружить и доказать виновность лиц, атако- 
вавших сеть. 

После достопамятной атаки пользователи стали об- 
винять во всем случившемся не только Морриса, но и 
транспортный протокол ТСР/ІР, утверждая, что сам 
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протокол не соответствует требованиям обеспечения 
безопасности. Однако в ответ специалистами было 
заявлено, что вирус вызвал серьезные последствия в 
силу недостатков средств обеспечения безопасности 
систем, но не сети. 

Вирус распространялся через программы, входящие 
в систему ІІМІХ, которые, как оказалось, были 
написаны недостаточно хорошо и имели дыры в схеме 
безопасности. Пикантность ситуации состояла в том, 
что существуют другие программы, работающие по 
тем же алгоритмам ничуть не хуже, а то и лучше упо- 
мянутых злосчастных программ, но при этом не имею- 
щие дыр в безопасности. Те системы в Іпіегпеі, кото- 
рые использовали эти альтернативные программы, из- 
бежали поражения вирусом. Это доказывает, что 
ТСР/ІР в состоянии поддерживать безопасный 
трафик. 


Как это судили 

•*НЬЮ-ЙОРК, 9. (ТАСС) Пока Ро- 
берт Моррис лишь смущенно улы- 
бается перед объективами репорте- 
ров — он уже стал героем дня в 
США, но еще не ясно, смогут ли 
американские власти доказать, что 
он еще и преступник. **У нас нет ни- 
какого опыта наказаний за такие де- 
ла*\ — заявил представитель ФБР...** 

Советская Россия, 10.11.88 

**Вся эта история выглядит и как 
захватывающая драма отца, сына и 
колоссальной электронной игры, и как 
наихудишй результат веселой продел- 
ки, в которой непреднамеренность не 
может служить оправданием. Разбор 
этого дела в суде позволит выяснить 
соответствие нынешнего законода- 
тельства, направленного против 
** электронного саботажа**, уровню 
развития вычислительных систем и 
средств. Очень важно доказать прес- 
тупность подобных действий, хотя в 
данном конкретном случае безусловно 
имеет смысл смягчить наказание**. 

ХЛЭСайланд 

Четверг, 10 ноября 1988 года. 

19:03 ѴІВ Утверждение, что “действия, предприня- 
тые в отношен ии“ Морриса и подобных ему лиц бу- 
дут “действиями общества в области компьютерной 
безопасности**. 

20:40 РІ8КЗ Официальное сообщение о ситуации в 
Корнеллском университете, откуда, по-видимому, 
был запущен вирус. Выводы сопровождаются ком- 
ментарием, какой Моррис хороший; высказывается 
уверенность, что его наказание не будет **слишком 
суровым**. 



Представляет интерес юридическая сторона дела. 

Долгое время ФБР не могло выдвинуть официаль- 
ного обвинения в отношении автора вируса, хотя по 
заказу этого уважаемого ведомства Гарвардским и 
Корнеллским университетами были подготовлены об- 
зоры существующего законодательства, касающегося 
“компьютерных** преступлений. Несмотря на наличие 
относительно новых законодательных актов, таких как 
Закон о злоупотреблениях и мошенничестве с помо- 
щью компьютеров от 1986 года (Сотриіег РгаисІ апб 
АЬизе Асі оГ 1986), выдвинуть обвинение в отношении 
лица, злоупотребившего многомашинной компьютер- 
ной системой, каковой является любая компьютерная 
сеть, было нелегко. 

В конце концов, поскольку пораженные вирусом 
системы входили в состав компьютерной сети, контро- 
лируемой правительством США, распространение ви- 
руса было признано действием, нарушившим закон. 
Но и после этого осталось неясным, как квалифициро- 
вать действия автора вируса — как преступление или 
как обычное хулиганство. В соответствии с уже упо- 
минавшимся законом от 1986 года в случае квалифи- 
кации действий Морриса как “несанкционированного 
доступа к правительственным компьютерам**, ему гро- 
зил крупный штраф и тюремное заключение сроком 
до 10 лет. 

22 января 1989 года суд присяжных признал 

Морриса виновным. Если бы осуждающий вердикт 
был утвержден без изменений, то Морриса ожидали 
бы 5 лет тюремного заключения и 250000 долларов 
штрафа. Однако адвокат Морриса Томас Гидобони 
(ТНотаз СиібоЬопі) сразу же заявил протест и нап- 
равил все бумаги в окружной суд с прошением отк- 
лонить решение суда. 

Защита Морриса основывалась на двух посылках: 

- на том, что формулировка закона неопределенна и 
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СУЕТА ВОКРУГ РОБЕРТА ИЛИ МОРРИС-СЫН И ВСЕ, ВСЕ. ВСЕ... 


СКОЛЬКО стоил ВИРУС МОРРИСА 


По самым скромным оценкам, 
инцидент с вирусом Морриса стоил 
свыше 8 миллионов часов потери дос- 
тупа и свыше миллиона часов пря- 
мых потерь на восстановление рабо- 
тоспособности систем. Общая стои- 
мость этих затрат оценивается в 98 
миллионов долларов. Ущерб был бы 
гораздо большим, если бы вирус из- 
начально создавался с разруши- 
тельными целями. 

Столь необычайно большая сумма 
ущерба объясняется гигантскими 
масштабами пораженных сетей (в ос- 
новном — Іпѣегпеі) и значительным 
количеством пораженных систем. 
Іпіегпеі объединяет 1200 отдельных 
сетей, состоящих в целом из 85000 
узловых компьютеров. Вирус пора- 
зил свыше 6200 компьютеров. В ре- 
зультате вирусной атаки большин- 
ство сетей вышло из строя на срок до 
пяти суток. Пользователи, чья дея- 
тельность зависит от доступа к сети, 
оказались полностью изолированы, 
то есть продуктивность их работы 
резко снизилась. Компьютеры, вы- 
полнявшие коммутационные функ- 
ции, работавшие в качестве фа^-сер- 
веров или выполнявшие другие 
функции обеспечения работы сети, 
также вышли из строя. Потеря дос- 
тупа и вынужденный простой машин 
являются косвенными потерями, свя- 
зсшными с инцидентом, и оценивают- 
ся в сумму примерно 65 миллионов 
долларов. 

Прямой ущерб состоит прежде все- 
го в затратах времени специалистов 
на определение пораженных систем, 
дезинфицирование этих систем и вос- 
становление их нормальной работо- 
способности. В первые часы атаки 
мало кто знал алгоритм работы виру- 
са, поэтому большинству систем рабо- 
тоспособность была возвращена толь- 
ко после дезинфекции. Процесс дез- 
инфекции потребовал десятки тысяч 
человеко-часов. После дезассемблиро- 
вания вируса сотни программистов 
по всей стране занялись разработкой 
ловушек для вируса и созданием 
"заплат” на месте обнаруженных ви- 
русом "дыр" в подсистеме безопаснос- 
ти своих систем, ^и затраты также 
оцениваются в десятки тысяч челове- 
ко-часов рабочего времени. Перечис- 
ленные здесь и другие виды деятель- 
ности, связанные с вирусом и продол- 
жавшиеся иногда на протяжении не- 
дель, оцениваются в 796000 челове- 
ко-часов, что, при принятой в США 
средней стоимости часа работы прог- 
раммиста в 22 доллара, состсівляет 
свыше 17 миллионов долларов. 

Время, затраченное администр>ато- 
рами и операторами, несколько 
меньше времени, затраченного прог- 
раммистами, и составляет свыше 
300000 часов. При средней стоимости 
часа работы персонала этого уровня в 
42 доллара, общая стоимость потерь 
составляет свыше 15 миллионов дол- 
ларов. 


Іпіегпеі: 1200 сетей, охватывающих около 85200 узловых 

компьютеров 

Инфицировано: 6200 машин (7,3% компьютеров сети). 


КОСВЕННЫЕ ПОТЕРИ 

Потерн машинного 
времени 


Машины часами не имели 
доступа к сети 

Пользователи часами 
не имели доступа к сети 

Накладные расходы 
за час 


СТОИМОСТЬ 


2.076.880 


20 долл. 


41.537.600 


ПРЯМЫЕ ПОТЕРИ 

Время работы 
программистов 


Остановка, тестирование 
и перезагрузка 
42.700 машин 

Начальный анализ проб- 
лемы на 12.400 машинах 

Идентификация, изоляция, 
удаление, чистка, восста- 
новление работоспособнос- 
ти (6200 машин) 

Реинфекция, удаление из 
сети, остановка, анализ, 
тестирование 

Создание заплат, отладка, 
установка, тестирование, 
контроль и сопровождение 

Анализ вируса, дезассембли- 
рование, документирование 
(в каждой из 1200 сетей) 


64.050 час 


49.600 час 


74.400 час 


62.000 час 


62.000 час 


192.000 час 


Исправление всех систем 
^NIX, тестирование, 

контроль 105.000 час 

Дрзггие проверки, технические 
совевцания, другие связанные с 
инцидентом события 187.000 час 


ОБЩЕЕ ЧИСЛО ЧАСОВ 
Средняя стоимость часа 


ПРЯМЫЕ ЗАТРАТЫ 


187.000 час 

796.050 час 
22 долл. 

17.513.100 

0Б1ІІИЕ ЗАТРАТЫ: 
9^53.260 долл. 


Потеря 

доступа 


8.307.520 


3 долл. 


24.922.560 


Время работы 
администраторов 


1.000 час 


11.000 час 


2.000 час 


12.000 час 


18.000 час 


22.000 час 


6.000 часов 


264.000 час 

336.000 час 
42,50 долл. 

14.280.000 
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оставляет открытой интерпретацию доказательства 
преднамеренности совершенных действий; 

- и на том, что закон не отражает специфику функ- 
ционирования компьютеров в 1990-х годах: в законе 
речь идет о несанкционированных действиях в отно- 
шении отдельного компьютера, а в рассматриваемом 
случае была поражена многомашинная система — 
компьютерная сеть. 

Прежде чем признать Морриса виновным, суд дос- 
таточно быстро установил несколько признаков прес- 
тупления. 

Самым большим мошенничеством во всей этой ис- 
тории является то, что Моррис вошел в сеть для запус- 
ка вируса без авторизации. 

Суд определил, что вирус Морриса причинил ущерб 
не менее чем на 1 000 долларов, хотя власти предста- 
вили более 40 свидетельств, которые в совокупности 
утверждают, что за счет потери производительности 
вирус Морриса обошелся не менее чем в 
150000 долларов, а промышленная ассоциация по 
компьютерным вирусам оценила стоимость 
потерянного времени и людских ресурсов, а также 
сверхурочных затрат на удаление вируса из тысяч 
компьютеров примерно в 100,000,000 долларов. 

Защита особенно настаивала на том, что вирус не 
поразил системы, связанные с обработкой денег; влас- 
ти вынуждены были признать, что все трудности зак- 
лючались в выключении машины, отсоединении ее от 
сети, повторном включении и проверке. 

Далее, защита подчеркивала факт, что ресурсы в 
основном были затрачены на приведение нарушенной 
системы безопасности в состояние, предшествовавшее 
атаке, и дизассемблирование обнаруженного вируса с 
целью выяснения его опасности. При этом, поскольку 
электронная почта сети во время вирусной атаки не 
работала, многие абоненты часами пытались дизассем- 
блировать вирус, не подозревая, что это уже сделано 
другими абонентами. 

Другим доводом защиты был тезис о том, что дока- 
занные разрушения не обязательно являются прямым 
следствием работы вируса, то есть затраты ресурсов 
могли быть вызваны чем-либо помимо вируса. Напри- 
мер, имелись показания о том, что значительное вре- 
мя пользователями было затрачено на проверку отсут- 
ствия в вирусе “троянских коней“, “часовых бомб“ 
или каких-либо иных разрушительных программных 
средств. В действительности вирус не содержал подоб- 
ных элементов, поэтому защита объявила неправомоч- 
ными попытки возложить на Морриса ответственность 
за длительные усилия, направленные на то, чтобы раз- 
рушить собственные необоснованные подозрения. 

Защита подчеркнула также тот факт, что электрон- 
ную почту мог использовать кто угодно для связи с 
кем угодно, причем без согласия на то адресата, тогда 
как обе эти программы в процессе работы занимают 
мощности и память получателя. На основании этого 


Гидобони высказал утверждение, что все, кто автори- 
зован в Іпіегпеі, имеют привилегии, достаточные для 
использования Зепбшаіі и Ріп^ег для связи с другими 
пользователями и, более того, невозможно установить, 
кто именно обрат^ся к данному абоненту, поскольку 
для обращения к любому абоненту никакой авториза- 
ции не требуется вообще. При этом Гидобони справед- 
ливо заметил, что подразумеваемая эффективность ав- 
торизации состоит в обязательной уникальной иденти- 
фикации каждого пользователя при каждом вхожде- 
нии в систему, в частности в Іпіегпеі. 

Небольшое препирательство на суде между защитой 
и обвинением произошло по поводу того, имело ли бы 
место нарушение закона, если бы Моррис не допустил 
программной ошибки. Эксперт Департамента Юсти- 
ции Марк Раш заявил, что если бы вирус работал точ- 
но так, как было задумано автором, администраторы 
узлов сети потеряли бы время на локализацию и уда- 
ление вируса; следовательно, существенный ущерб 
был бы нанесен даже в том случае, если бы ошибка не 
была допущена. 

Хотя защитник не стал оспаривать этот вывод сра- 
зу, вне зала заседаний он заявил, что если бы прог- 
рамма работала так, как задумывал его клиент, ника- 
кого ущерба не было бы вообще; и прояви некоторые 
адмистраторы немного любознательности в отношении 
появившегося вируса, они вполне смогли бы проанали- 
зировать его на основании достаточного количества 
сообщений о вирусе, поступавших от других поль- 
зователей. 


Что сказал Пентагон 


свидетельству ** Нью-Йорк 
Таймс"*, представители Пентагона, 
стремясь умерить опасения, что 
ключевые военные компьютеры уяз- 
вимы для подобных диверсий, 
заявили, что такой вирус не может 
проникнуть в секретные 

компьютерные сети, управляющие 
системами ядерного оружия и 
хранящими в памяти военные 
планы». Однако эксперты указывают, 
что происиіедишй случай сви- 
детельствует о том, сколь уязвима 
компьютерная сеть**. 

Московская правда, 6.11X8 

Вирус Морриса стал причиной очень серьезного бес- 
покойства такого уважаемого и солидного учреждения, 
как Пентагон. 

Не секрет, что всеобщая компьютеризация, как 
принято у нас говорить, американского общества не 
обошла стороной и эту организацию. 

Компьютеры позволили создавать надежные систе- 
мы связи с умопомрачительной скоростью передачи 
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данных, что само по себе весьма привлекательно для 
подобных государственных структур; компьютеры под- 
держивают обширные банки данных, позволяющие 
эффективно управлять столь масштабной организа- 
цией; компьютеры встраиваются практически во все 
новейшие системы вооружения, включая и ядерные, 
поскольку это резко повышает и эффективность при- 
менения этих систем, и оперативность их “срабатыва- 
ния“; компьютеры составляют сердцевину всех навига- 
ционных систем и так называемых систем раннего 
обнаружения. Вспомните хотя бы пресловутую СОИ: 
ведь даже наши средства массовой информации все 
уши прожужжали о том, что эта милитаристская за- 
думка практически во всех, аспектах основывается на 
использовании вычислительной техники. Однако тут 
же наши газеты вещали, что американские военные, а 
с ними и “все человечество**, все больше становятся 
заложниками компьютеров. 

Как ни странно, последний вывод был не так уж 
далек от истины. Нарушение работы компьютерных 
сетей командования и управления, по мнению самих 
американцев, означало бы катастрофу. 

Осознав всю опасность вирусов, правительство 
США спешно позаботилось об обеспечении 
надлежащей безопасности своих наиболее важных 
информационных систем, соединенных каналами 
связи с другими, незащищенными системами. По 
свидетельству специалистов, ответственных за защиту 
военных компьютерных систем, **в закрытые системы 
Пентагона встраиваются специальные механизмы 
защиты, которые работают настолько тонко, что лишь 
немногие люди знают, что система фиксирует каждый 
шаг пользователя**. В частности, секретные сети 
передачи данных были защищены шифрующими 
устройствами для закрытия всех данных, поступающих 
на терминал и уходящих с него. Считалось, что 
помимо защиты от проникновения иностранных 
спецслужб, применение новых криптографических 
методов лишит компьютерных взломщиков (по 
крайней мере на ближайшее время) возможности 
совершать различные манипуляции с секретными 
военными компьютерными системами. 

Гораздо сложнее обстоит дело с защитой публичных 
компьютерных сетей от неавторизованного доступа 
пользователей или, еще хуже, **компьютерных взлом- 
щиков** — хакеров. Особенно трудна в этом отноше- 
нии защита военных сетей, соединенных с общедос- 
тупными (риЫіс ёошаіп) сетями. 

Ввиду этого в 1982 году Белый Дом даже был вы- 
нужден отказаться от участия в компьютерном консор- 
циуме 17 стран, так как выяснилось, что это позволит 
советским экспертам получать доступ к несекретным, 
но достаточно важным американским базам данных. 

В соответствии с четырехлетней программой по 
борьбе с компьютерными вирусами ОоО еще в 1987 
году ужесточило режим обеспечения безопасности 
своих сетей. В некоторых наиболее важных компью- 


терных сетях были приняты следующие меры: 

- максимально ограничен доступ; 

- детально фиксировались все операции пользовате- 
лей; 

- циркулирующая в сетях информация шифровалась; 

- в распоряжение пользователей сетей 
предоставлялись программы-вакцины, выявляющие 
несанкционированные изменения в программном 
о(5еспечении и данных; 

- наиболее важные, содержащие секретные сведения 
вычислительные системы стали полностью автоном- 
ными, то есть были отключены от сетей. 

В январе 1981 года с целью определения пригоднос- 
ти предлагаемых различными разработчиками ком- 
пьютерных систем для нужд ОоО был создан Центр 
компьютерной безопасности министерства обороны 
США. Позднее, в сентябре 1985 года, этот центр был 
переименован в Национальный центр компьютерной 
безопасности (ЫаГюпаІ Сотриіег Зесигііу Сепіег; 
N€80 и перешел под ласковое крылышко Агентства 
национальной безопасности (Маііопаі 8есигі1у А^епсу; 
М8А). 

МС5С и ныне оценивает пригодность компьютерных 
систем с точки зрения безопасного использования не 
только в вооруженных силах, но и в различных госу- 
дарственных учреждениях, фирмах, выполняющих го- 
сударственные и военные заказы; при этом оцени- 
вание продуктов ведется по строго определенной прог- 
рамме, предусматривающей проверку строго опреде- 
ленных механизмов и средств. Это обстоятельство 
обеспечивает возможность сравнения рейтингов без- 
опасности разнородных продуктов. 

Оценивание осуществляется на основе стандарта, 
известного под названием **оранжевая книга**. Сог- 
ласно стандарту все компьютерные системы условно 
разделяются на четыре основных группы безопасности, 
которые в свою очередь делятся на классы безопаснос- 
ти. В настоящее время существуют следующие классы 
безопасности — в порядке увеличения гарантирован- 
носи защиты: О, С1, С2, В1, В2, ВЗ, А1. 

Присвоенный компьютерной системе класс без- 
опасности часто называют рейтингом безопасности. 

Продукты, не прошедшие официальной проверки 
МС8С, не могут быть использованы для обработки зак- 
рытой информации в военной сфере или государ- 
ственных учреждениях. Фирмы-разработчики програм- 
много обеспечения весьма заинтересованы в полу- 
чении и повышении полученных официальных рей- 
тингов безопасности для своей продукции, поскольку 
наличие рейтинга безопасности — необходимое усло- 
вие для получения фирмой значительных государст- 
венных и военных заказов, а также хорошая реклама 
продукции фирмы. 

Многие исследования в области компьютерной 
безопасности также финансировались военными. 

Так что, как видите, безопасность собственных 
компьютерных систем весьма волновала Пентагон 
задолго до 1988 года. 
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представьте теперь, что должны были чувствовать 
уважаемые американские военные, когда обнаружив 
лось, что Мііпеі практически мгновенно выведена из 
строя вирусом! 

Вирус Морриса показал уязвимость сетевых струк- 
тур, поставил под сомнение надежность средств связи 
Пентагона и обороны США в целом. Фактически Мор- 
рис для ОСА был тем же, кем и Руст для советских 
войск противовоздушной обороны. 

Оказавшись перед фактом, что все многолетние по- 
пытки убедить на- 
логоплательщиков в 
надежности воен- 
ных компьютерных 
систем пошли нас- 
марку, Пентагон 
изо всех сил поста- 
рался достойно вст- 
ретить неизбежный 
шквал негодования. 

Уже 3 ноября пред- 
ставитель ОСА, 
стремясь успокоить 
общественное мне- 
ние, публично приз- 
нал факт заражения 
сетей министерства 
вирусом, однако пы- 
тался принизить 
значение происшед- 
шего. Он заявил: 

“Вирус был выявлен 
в нескольких глав- 
ных компьютерах, 
подключенных к се- 
ти Аграпеі и к той 
части МПпе!, кото- 
рая содержит сведе- 
ния несекретного 
характера... Хотя 
некоторые важные 
данные министерст- 
ва обороны в той 
или иной мере пос- 
традали, файлы, со- 
держащие секрет- 
ную информацию, 
связанную с вопро- 
сами национальной 
безопасности, воздействию вируса не подверглись^. 

Нетрудно догадаться, что число оптимистов, кото- 
рые верят заявлениям официальных представителей 
Пентагона относительно неуязвимости секретных вы- 
числительных систем этого ведомства, значительно 
убавилось. Да и ряд военных экспертов были далеки 
от оптимизма в оценке неуязвимости военных вычис- 
лительных систем. 

Снова всплыла история с негласной проверкой сте- 
пени этой “неуязвимости**, предпринятой несколько 


лет назад группой специалистов. По образному выра- 
жению одного члена этой группы, правительственные 
системы “оказались похожи на швейцарский сыр, че- 
рез дырки которого проникнуть внутрь можно без осо- 
бого труда**. 

Масла в разгоравшийся огонь уничтожающей кри- 
тики подлило сообщение о том, что заражения ком- 
пьютерных систем Пентагона вирусом Морриса можно 
было избежать, если бы в свое время соответствующие 
органы прислушались к предупреждениям специалис- 
тов об уязвимости 
ІІМІХ и рекоменда- 
циям использовать 
вместо нее более за- 
щищенную опера- 
ционную систему 
ѴМ8. 

Основным и дос- 
таточно сильным 
доводом Пентагона 
был факт, что вы- 
числительные систе- 
мы и сети, в кото- 
рых проходит или 
содержится секрет- 
ная информация, 
являются полностью 
автономными, то 
есть они физически 
не соединены с 
внешними компью- 
терными системами. 
Тут же следовал вы- 
вод о том, что вирус 
Морриса не может 
поразить основные 
военные системы, 
поскольку он (ви- 
рус) просто не смо- 
жет в них попасть! 

Как говориться, 
три **ха-ха“: а что 
было бы, если бы 
Моррис или кто-ни- 
будь еще запустил 
аналогичный вирус 
не во “внешней** 
системе, каковой 
может считаться Аграпеі, а в любой из закрытых “ав- 
тономных** систем? Чем бы тогда закончилась вся эта 
история? 

Неважно, что вирус Морриса не уничтожал данные, 
а “просто** блокировал сеть. Чтобы представить себе 
возможные результаты блокировки ВОЕННОЙ компью- 
терной сети, совсем не нужно обладать чрезвычайно 
развитой фантазией. Бывший начальник всех инфор- 
мационных систем Пентагона С.Уолкер (ЗіерНеп 
>Ѵа1кег) по этому поводу заявил: “Если бы кто-нибудь 
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смог сделать с системой МОИАО (КогіН Атегісап 
Аегозрасе Оеіепсе Соштапд — Командование аэрокос- 
мической обороны Северной Америки) то же самое, 
что сделал Моррис с Аграпеі. ущерб был бы огромен". 
Подумайте сами, что значит, например, вывод из 
строя военной системы предупреждения о нападении 
даже на несколько минут с учетом, что так назы- 
ваемое "время подлета" к американскому континенту 
межконтинентальных ядерных ракет составляет около 
получаса. А ведь вирус Морриса заблокировал Аграпеі 
минимум на сутки! 

Несмотря на очевидный промах с вирусом Морриса, 
военные специалисты оценивают проблему вирусов 
весьма дальновидно. Например, один из них заявил: 
"Возможные негативные последствия наступательного 
использования вирусов настолько велики, что по раз- 
рушительной силе и площади поражения я сравнил бы 
их с ядерным или химическим оружием". 

Что же предпринял Пентагон после столь дорого 
стоившего ему инцидента? 

После упоминавшейся ранее встречи, состоявшейся 
8 ноября, представитель Пентагона заверил, что "про- 
цесс совершенствования программ идет полным хо- 
дом". Было объявлено также о дополнительных мерах, 
которые будут приняты для обеспечения безопасности 
военных компьютерных сетей: 

- еще более ужесточается процедура доступа пользова- 
телей к аппаратным и программным средствам; 

- внедряется новое сложное сетевое программное обес- 
печение, которое "выявляет и блокирует" все попыт- 
ки вируса проникнуть 
в систему; 

- вводится более жест- 
кий стандарт безопас- 
ности для военных 
компьютеров. 

В начале 1989 года 
стало известно, что 
ОАкРА планирует на- 
чать разработку новой 
национальной компьютерной сети Оеіепсе ЯезеагсН 
Іпіегпеі (Сеть исследований Министерства обороны — 
ОкІ), которая придет на смену сети Аграпеі. Сеть 
ОЯІ создаст информационно-справочную базу для 
проводимых Управлением исследований и разработок 
в области систем связи, контроля и управления, 
обеспечит доступ специалистов управления и 
корпораций-подрядчиков к новому поколению систем 
параллельной обработки данных. Кроме того, сеть 
будет своего рода полигоном для отработки новых 
подходов и концепций развития сетевых 
вычислительных структур ОоО. В процессе разработки 
новой сети будет уделено большое внимание созданию 
эффективных средств обеспечения безопасности сети 
и циркулирующих в ней данных, способных 


гарантировать надежную защиту от вирусных атак и 
других нарушений режима секретности. 

В настоящее время разрабатываются так называе- 
мые "доверительные системы" (Ігизіесі зузіешз). кото- 
рые надежно гарантируют, что пользователь получает 
доступ только к такой информации, какую ему поло- 
жено читать, и может совершать с системой такие 
операции, на какие он имеет официальное разреше- 
ние. Специалисты утверждают, что "доверительные 
системы" позволят более грамотно объединять ком- 
пьютеры в информационные сети без снижения уров- 
ня безопасности. Отсутствие таких систем — главное 
препятствие к более эффективному использованию 
компьютеров в закрытых информационных сетях. До 
окончания их разработки информационные сети нель- 
зя считать полностью безопасными с точки зрения 
возможности несанкционированного проникновения. 

Таким образом, риск утраты секретной информации 
пока по-прежнему реален. 

А теперь относительно сделанного мною несколько 
раньше намека на крайне щекотливое положение, в 
котором оказался ЫС8С. 

Как я уже объяснил, ЫС8С обязан рождением Пен- 
тагону, так что "слава" одного из них косвенно "осе- 
няет" и другого. Но на деле все обстоит гораздо инте- 
реснее: Роберт Таппан Моррис является сыном одного 
из наиболее известных правительственных экспертов 
по компьютерной безопасности — научного руководи- 
теля ЫС8С! Каково! 

Эффект будет более поразительным, если учесть, 
что во время доклада Конгрессу в 1983 году именно 

Моррис-старший гово- 
рил о возможности об- 
мана технически обра- 
зованными новичками 
специалистов по без- 
опасности как о "со- 
вершенном нонсенсе". 

Но и это еще не все! 
Оказывается, баловство 
с компьютерными ви- 
русами для Моррисов 
чуть ли не семейная традиция: Моррис-старший. рабо- 
тая в 60-х годах в ВеІІ ЬаЬогаІогіез, принимал участие 
в создании игры, основанной на компьютерном вирусе. 
Ядром этой игры, которая называлась Соге АѴагз, была 
программа, которая могла размножаться и пыталась 
разрушить программы других игроков. 

Моррис-отец прокомментировал события следую- 
щим образом: "Некоторые считают, что суть проблемы 
состоит в том. что в США выросло новое поколение 
хорошо разбирающихся в технике людей, которые при 
желании извлечь из компьютерной системы секретные 
данные в состоянии преодолеть все барьеры, соз- 
даваемые специалистами по защите информационных 
систем крупнейших американских корпораций и ми- 
нистерства обороны... Однако все не так просто". 


Возможные негативные последствия нас- 
тупательного использования вирусов нас- 
только велики^ что по разрушительной 
силе и площади поражения их можно 
сравнить с ядерным или химическим ору- 
жием. 
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По мнению Морриса>старшего, именно новый вирус 
позволил выявить эти уязвимые места, поэтому его 
сын якобы сыграл ^^конструктивную роль** и содейство- 
вал совершенствованию методов организации компью- 
терных сетей и управления ими. 

Тем не менее инцидент существенно не отразился 
на карьере Морриса-отца. По крайней мере в начале 
1989 года он был избран в специальный консультатив- 
ный совет при Национальном институте стандартов и 
технологии (МІ8Т; бывшее Национальное бюро стан- 
дартов) и курирующем его министерстве торговли. 
Этот совет образуется ежегодно в соответствии с поло- 
жениями Закона о безопасности компьютеров (Сотри- 
Іег Зесигііу Асі о1 1987). Задачами этого совета яв- 
ляются выработка заключений и рекомендаций по 
вопросам безопасности вычислительных систем прави- 
тельственных ведомств США, а также решение проб- 
лем, возникающих в процессе разработки и внедрения 
новых стандартов защиты несекретной, но важной ин- 
формации, хранящейся или циркулирующей в этих 
системах и тому подобного. 


Что об этом думали 


**3начение происшедшего не в кон- 
кретных сиюминутных последствиях. 
Инцидент этот ~ напоминание о 
**Челленджере“ и Чернобыле. Мы соз- 
дали такие сложные системы^ что 
порой не можем полностью удержать 
их под своим контролем**. 

Дж.Уайэсибауи, сотрудник МГГ 

**Молодому Моррису, на удивление, 
симпатизируют очень многие — это 
явно прослеживается по потоку сооб- 
щений. Думается, настала пора иск- 
лючить из компьютерной прсхрессии 
позицию гребенок есть ребенок». Или, 
как лучше сказано в Библии: »Когда я 
был ребенком, я говорил как ребенок, 
я думал как ребенок, я рассуждал как 
ребенок; когда я стал взрослым, я 
отказался от детских путей»**. 

Филипп Гарднер, полковник в отставке 

**Мы не в состоянии учиться на соб- 
ственных успехах, но зато отлично 
учимся на собственных промахах**. 

Генри Петровски 

Пятница, 11 ноября 1988 года. 

09:27 ЯІ8К8 обсуждение непригодности ПМІХ для 
использования в системах с более-менее серьезными 
требованиями к безопасности (медицинские, коммер- 
ческие и государственные). 

19:55 Ѵ1К Призыв компьютерных профессионалов 
наказать злоумышленника за неэтичное поведение. 


Импульсивный сомнительный комментарий Тэда 
Коппеля из Ыі^НіУпе, что Роберт Моррис имеет бу- 
дущее в области компьютерной безопасности. 

Научная и компьютерная общественность раздели- 
лась в оценке вины Морриса. 

Администраторы систем, проведшие дни в борьбе с 
вирусом, готовы были линчевать Морриса, попадись он 
в их руки. Немудрено: во-первых, обнаружение неиз- 
вестного вируса вызвало у многих нешуточный испуг 
за свои системы, а во-вторых, атака стала причиной 
внеплановой работы многих ученых и исследователей, 
а также лишила еще более широкий круг пользовате- 
лей возможности работать с сетями, объединяющими 
научные центры страны. Естественно это замедлило 
ход научных и инженерных исследований и раз- 
работок. 

Результатом вирусной атаки можно считать также 
отмеченное многими очевидное сокращение обмена 
информацией посредством компьютерных сетей между 
университетами, лабораториями и так далее. 

Тем не менее многие эксперты по компьютерной 
безопасности заявили, что вирус стал важной 
демонстрацией потенциальной уязвимости компьютер- 
ных систем и последствия этой атаки являются, безус- 
ловно, положительными в том смысле, что атака выз- 
вала всеобщую тревогу пользователей и их заинтересо- 
ванность в разработке и внедрении средств защиты от 
возможных атак такого рода в будущем. 

На это оппоненты ответили доводом, что усиление 
средств компьютерной безопасности повредит 
экономике страны. 

Существует мнение, что данный вирус в действи- 
тельности является представителем полезного вида се- 
тевого программного обеспечения. Этот класс прог- 
рамм может быть с успехом использован для обес- 
печения связи между системами и синхронизации их 
совместной работы. Эти же программы могут по- 
служить и для выявления некорректной работы сети, 
выполнения задач с большим объемом вычислений, 
распараллеленных по нескольким системам так, как 
если бы все эти системы представляли собой единое 
целое, а также в качестве скоростной электронной 
почты. 

Инцидент подтвердил высказанную ранее мысль, 
что, если ЭВМ связана с “внешним миром**, то есть 
подключена к сети, то не может быть и речи о гаран- 
тированной защите информации. 

Большинство причисляет Морриса к многочисленно- 
му племени хакеров. Этот термин первоначально ис- 
пользовался в отношении компьютерной субкультуры, 
однако в настоящее время употребляется в основном 
как синоним компьютерных взломщиков. В более ши- 
роком, и думается, более правильном понимании ха- 
кер — это человек, достигший значительных вершин в 
области компьютерных наук и фанатично преданный 


3 Зак. 2399 
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своему компьютерному призванию. Хакеры получают 
настоящее наслаждение от удачно написанной прог- 
раммы (не важно, своей или чужой); коллекциони- 
руют всевозможного рода ухищрения и неожиданные 
решения в программировании. Именно хакеры обычно 
первыми осваивают до тонкостей новые программные 
пакеты и системы, равно как именно хакеры стремят- 
ся выжать из новой техники все, на что она способна. 

Если понимать термин “хакер“ 
в предложенном смысле, то я сог- 
ласен считать Морриса хакером, 
поскольку он не стремился напа- 
костить, а хотел разобраться с об- 
наруженными им возможностями. 
Кстати, профессор Корнеллского 
университета — специалист в области компьютерной 
техники — признал, что Моррис вполне усвоил учеб- 
ную программу и поэтому “может считаться хакером с 
Гарвардским образован ием“. 

Что же касается электронных взломщиков, то они в 
последнее время серьезно заинтересовались компью- 
терными вирусами как одним из наиболее эффектив- 
ных и безликих способов внедрения в системы. В ряде 
публикаций даже появились рекомендации и инструк- 
ции, подробно объясняющие, как составить програм- 
му-вирус. 

Как вы уже знаете, АНБ и ФБР пытаются ограни- 
чить распространение небезопасной информации. Од- 
нако несмотря на все усилия АНБ и ФБР, копии ви- 
руса Морриса стали для хакеров эталонами искусства 
программирования. Они учатся на ней, пытаются ее 
усовершенствовать. Предполагается, что остатки виру- 
са Морриса по-прежнему существуют в отдельных уз- 
лах сети Іпіегпеі. Кроме того, считается, что около 
1000 человек в США владеют исходным кодом вируса 
Морриса. Так что, если кто-нибудь из обладателей ис- 
ходного кода держит его не только для коллекции, мы 
скоро сможем снова наблюдать нашествие этого виру- 
са, но на этот раз он будет работать лучше, в том 
смысле, что принесет гораздо больше вреда. 

В развитие мысли о благотворном влиянии хакерст- 
ва можно привести существующее среди специалистов 
мнение, что США удерживают мировое лидерство в 
вычислительной технике и программном обеспечении 
благодаря таким людям, как Моррис. Пытаются даже 
обосновать такую зависимость: все успехи США в раз 
витии вычислительной техники связаны с одиночками- 
индивидуалистами. 

В качестве доказательства приводится факт, что 
удачные программы, получившие широкое распростра- 
нение, — >Ѵог(І8Іаг, Ьоіиз 1-2-3, Ѵізісаіс — разрабо- 
тали одиночки или небольшие группы. Полезно вспом- 
нить также, что два друга — бывшие “взломщики** 
Возняк и Джобс изобрели персональный компьютер, 
изменивший лицо Америки и всего мира. 

Зато программы, созданные большими коллектива- 
ми программистов (Ѵізі-Оп, іагх), оказались неудач- 


ными и привели к банкротству фирм-разработчиков. 

До недавнего времени социологи рассматривали ха- 
керов — в основном, конечно, из ультралевого крыла 
хакерства — как своего рода неудачников, пытались 
им помочь, трудоустроить в области информатики, яв- 
ляющейся предметом их интереса. Однако из этой за- 
теи ничего не вышло. Нелегальное проникновение 
стало для многих представителей субкультуры своего 
рода наркотиком. У некоторых из них удивительные 
судьбы. 

Так, талантливый программист Дж.Дрепер в 70-е 
годы провел шесть месяцев в тюрьме за “нелегальное 
использование телефонной сети**. После выхода из 
заключения он написал программу Еазу >ѴгіІег — 
весьма популярную в США программу обработки текс- 
тов, одну из первых, которая была использована в 
персональных компьютерах корпорации 1ВМ. 
Несмотря на финансовый успех программы, он не так 
давно был снова осужден за совершение очередного 
**компьютерного преступления**. 

Что же касается вопроса о вреде, наносимом хакер- 
ством, то думается, гораздо большую опасность для 
компьютерного мира представляют собой миллионы 
пользователей-непрофессионалов, получивших в свои 
руки мощную микротехнику. Именно некомпетентнос- 
тью пользователей во многом объясняется столь широ- 
кое распространение компьютерных вирусов. Ведь ви- 
русы создавались и раньше, но раньше не возникало 
**компьютерных эпидемий**. 

Например, Чейсик из лаборатории ІРЦ который те- 
перь тоже борется с компьютерными вирусами, еще в 
70-х годах писал вирусные программы в колледже. По 
его словам, это было своеобразным тестированием на 
зрелость, которое должеі^ был пройти каждый прог- 
раммист. В этом не было никакого злого умысла. 
Такие программы могли мешать компьютерным поль- 
зователям в реализации их замыслов, но ничего на 
разрушали. 

Когда Моррис-старший и Чейсик создавали свои ви- 
русные программы, компьютерный мир был сплочен- 
ным и высокодисциплинированным сообществом. В 
современном мире персональных компьютеров боль- 
шинство пользователей не являются компьютерными 
профессионалами. Это гораздо более хаотичное обра- 
зование, являющееся привлекательной мишенью для 
создателей вирусов. 

Еще одна интересная теория 
относительно современной (и са- 
мой совершенной) технологии раз- 
вития аппаратных и программных 
средств: хакеры отыскивают уязви- 
мые места систем и сетей — затем 
специалисты заделывают эти дыры. 
Примером такой **технологии“ опять же является дело 
Морриса. 

В силу всего сказанного не покажется крамольной 
мысль, высказанная Джозефом Хайландом, что ком- 
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мрюгу 


пьютерные хакеры являются достоянием нации и на- 
циональной головной болью. 

Как ожидается, одним из наиболее важных послед- 
ствий инцидента с вирусом Морриса будет резкое из- 
менение отношения к проблеме компьютерной без- 
опасности. Ряд экспертов, например, из консультатив- 
ной фирмы Егпзі & >ѴЬіппеу, настаивали на пересмот- 
ре всего используемого в стране программного обеспе- 
чения. Другие отвер- 
гают эту идею, пола- 
гая, что она обойдется 
слишком дорого, зай- 
мет много времени и 
ограничит право за- 
конных пользователей 
на совершенствование, 
исправление и адапта- 
цию программного 
обеспечения, негатив- 
но повлияет на форми- 
рование информацион- 
ного общества. 

Наиболее осторож- 
ные эксперты считают, 
что решение этой 
проблемы должно осу- 
ществляться на основе 
анализа соотношения 
‘‘стоимость/эффектив- 
ность“, поскольку су- 
ществует определен- 
ный предел, за кото- 
рым дальнейшее повы- 
шение уровня безопас- 
ности оказывается не 
только неэкономич- 
ным, но и неэффек- 
тивным. По образному 
выражению одного из 
них, “мы можем упо- 
добиться жильцу, кото- 
рый, постоянно совер- 
шенствуя и усложняя 
систему защиты своего 
жилища, в итоге не 
сможет в него по- 
пасть“. 


Эпилог 


Итак, почему же я предлагаю запомнить 
2 ноября 1988 года. 

Прежде всего потому, что начавшийся в этот день 


инцидент связан с компьютерным вирусом, считаю- 
щимся в настоящее время наиболее опасным. 

Следующим, весьма спорным, моим утверждением 
будет то, что вирус Морриса стал концом целого пе- 
риода в существовании такого явления, как ком- 
пьютерные вирусы. Компьютерные вирусы становятся 
все изощреннее и защищаться от них — как и бороть- 
ся с ними — становится все сложнее. С другой сто- 
роны. появляются 



более мощные средств 
защиты от 

компьютерных виру- 
сов. Все это позволяет 
предполагать, что в 
будущем вирусы будут 
создаваться хорошо 
подготовленными спе- 
циалистами, и пресле- 
доваться при этом бу- 
дут вполне определен- 
ные цели. Как сказал 
Стивен Росс, старший 
администратор фирмы 
бухгалтерских услуг и 
консультаций Оеііоіііе, 
Назкіпз & Зеііз: “Эпо- 
ха вирусов-шутих, не 
имеющих каких-либо 
определенных задач 
или целей, кончается, 
перед нами — эпоха 
ориентированных ви- 
русов“. 

Инцидент с вирусом 
Морриса затронул так- 
же столь многие проб- 
лемы, связанные с 
компьютерами, что на 
примере этого дела 
стоит внимательно и 
долго учиться, чтобы 
избежать повторения 
выявленных инциден- 
том недостатков в род- 
ных пределах. 


Что касается самого 
Морриса-младшего, то 
окончательно он был приговорен к трем месяцам 
тюрьмы и денежному штрафу в 270 тысяч долларов, а 
вдобавок был исключен из Корнеллского университета. 

Думается, однако, не стоит слишком сильно печа- 
литься о его дальнейшей судьбе: уже в январе 1989 го- 
да президент АПіап! Сотриіег Зузіешз Согр. Рон Грю- 
нер (Коп Сгипег) в ответ на вопрос журнала Сотри- 
Іепѵогіб по поводу намерений компании нанять на ра- 
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СУЕТА ВОКРУГ РОБЕРТА ИЛИ МОРРИС-СЫН И ВСЕ, ВСЕ, ВСЕ... 


боту Р.Т.Морриса, сказал следующее: “Некоторые 
очень известные в (компьютерной) промышленности 
люди начинали с хакерских проделок в самых изощ- 
ренных формах**. 

И.Моисеенков 

По материалам: 

Е.8раГГог(1 “ТНе Іпіегпеі ЛѴогш: Сгі5І5 апсі аИегшасН", 

Сошшипісаііоп оГ (Не АСМ, ѵо1.32, Іипе 1989. 

І.КосЫі5, М.ЕісЫп “ТЬе Іпіегпеі >Ѵопп: Місгозсоре апб 

Тѵѵеегеге: ТНе ѵопп Ггот МГГ'8 Регересйѵе", Соттипісайоп о1 
Ще АСМ, ѴОІ.32, Зипе 1989. 

С.АѴЬИе “Ѵіпізез апб >Ѵопіі8: Сатриз АПаскз**, Сошриіег & 
8есигі!у, №8, 1989. 

Р.СагсІ “Іпіегпеі АѴогш**, Сошриіег & 8есигі!у, №8, 1989. 
Е.ЗраГГогсІ “ТЬе Іпіете! АѴопп Рго^гатт: Ап Апаіувіз", АСМ 
СоттИее Кероіі, 1 989. 

H. НібЫапсІ **Кап(1от Ьііа & Ьуіеа**, Сошриіег & Зесигііу, №8, 
1989 

I. 8Нишап “Саае аЬои! по! саІсНей ѵіпі8“, 11МХ Тойау, РеЬгіагу 
5, 1989. 


М.АІехапдег **Оі88ес!іп^ !Ье Апаіошу о1 \Ѵогш**, 
Сошри!ег>ѴогШ, КоѵешЬег 14, 1988. 

Р.РіІеа, РЛоЬп8!оп, М.Кгаіг “ТЬе Сотриіег Ѵіпіз Сгіаіа", 1989. 
0.8Ш, Р.СаітоІІ “Опе тіаіаке апб “Нагт1еа8“ шізсіеі Ьгои^Ы 
по!оііе!у !о КоЬег! Моіті5 Іп.“, ТЬе АѴаІІ 8!гее! Іоигпаі, 
№ѵетЬег 1988. 

Ріпапсіаі Тішеа, №ѵешЬег 5-6, 1988, р.1-2. 

Ріпапсіаі Тітеа, №ѵешЬег 10, 1988, р.10. 

КаЬіге, №6195, 1988, р.97. 

Nа!иге, №6197, 1988, р.301. 

Тіте$, №ѵешЬег 5, р.4. 

Тітеа, №ѵетЬег 7, р.10. 

Тішев, №ѵешЬег 8, р.10. 

Тішез, NоѵетЬе^ 9, р.4. 

Іарап Тіше$, №ѵешЬег 6, 1988, р.З. 

Іарап Тітеа, №ѵешЬег 7, 1988, р.1, 7. 

8ип(іау Тітеа, №ѵешЬег 6, 1988, р.1 9. 

Ке\ѵ Уогк Тішеа, NоѵетЬе^ 26, 1988, р.1, 28. 

Лазарев А. Эти доверчивые компьютеры./ Эхо планеты. 
1988, ноябрь. 


Фирма 8НАКР начала постав- 
ки в СССР своего лазерного 
принтера ІХ-9500Е стоимостью , 
1340 долларов, ориентированно- 
го на использование в системах 
настольных издательств. 

ЗХ-9500Е — один из самых ком- 
пактных в мире лазерных прин- 
теров — примерно на треть 
меньше НР-ІІР и почти в два с 
половиной раза компактнее 
НР-ІІІ. 

Принтер может эм>'лировать 
работу НР Ьазег Зе! Зегіез II, 
Ерзоп РХ-80, ІВМ СгарЬісз 
Ргіпіег, ІВМ Ргоргіпіег и 
ОіаЫо-630. Выбор эмулятора 
осуществляется из меню на 
панели управления принтером. 

Скорость печати составляет 
6 страниц в минуту, максималь- 
ный формат бумаги А4, разре- 
шающая способность этого 
принтера 300x300 точек на 
дюйм. Обращает внимание то, 
что первая страница печатается 
после очень небольшой 
задержки. Оперативная память 
принтера — 512 Кбайт с 

возможностью расширения до 
4.5 Мбайт. Контроллер построен 
на процессоре 68000. 


Принтер использует шесть ре- 
зидентных фонтов. Возможно 
расширить их набор с помощью 
дополнительных картриджей. 

Кроме того, фирма 8НАЯР 
предполагает поставлять на со- 
ветский рынок цветной струй- 
ный принтер ЗХ-730 и цветной 
сканер ІХ-450. 

Принтер использует 48-струй- 
ную 4-цветную печатающую го- 
ловку и позволяет воспроизвести 
7 цветов. Разрешающая способ- 
ность составляет 180x180 точек 
на дюйм. Максимальная ширина 
изображения 345 мм. Принтер 
может найти применение в ар- 
хитектурных бюро или мастерс- 
ких дизайнеров. 

Сканер обеспечивает работу с 
разрешением до 300x300 точек 
на дюйм и воспроизводит свыше 
260 тысяч оттенков. Кроме того, 
возможно использование сканера 
в черно-белом режиме с 256 гра- 
дациями серого или в чисто 
“штриховом** режиме. 

Сканирование изображений 
возможно как с отражающих, 
так и с прозрачных оригиналов. 
В первом случае максимальный 


размер составляет 431x297 мм 
(формат АЗ), во втором — 
297x210 мм (А4). Возможна 
подстройка цветовых характе- 
ристик сканера для работы в па- 
ре с конкретным монитором или 
принтером. 

Цветоделение осуществляется 
посредством трех люминесцент- 
ных ламп с соответствующим 
спектром излучения и специаль- 
ной схемы с зарядовой связью 
фирмы 8НАКР. 

Как сообщил нам представи- 
тель фирмы Оі^ііаі ЕезеагсН, 
фирма готова выпустить новую 
версию операционной системы 
ОК-008. Это событие может 
произойти уже в конце августа 
этого года. 

Существующая сейчас версия 
ОК.-П05 5.0 по многим парамет- 
рам превосходит недавно выпу- 
щенную фирмой МісгозоП опера- 
ционную систему М8-008 5.0, а 
новая версия будет обладать еще 
более высокими характеристи- 
ками. 
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Н а страницах “КомпьютерПресс" 
часто эксплуатируется тема 
общения — общения между людьми. 

В этой статье мы несколько изменили 
ее направленность. Давайте поговорим 
с вами сегодня об общении 
с компьютерами. 



Устройства 
ввода информации 


Введение 

Как часто мы судим о человеке по его словам, а не 
по его делам. Для нас важнее то, что мы говорим сво- 
ему собеседнику и что он нам отвечает. И лишь ред- 
кие люди, в основном анатомы и психологи, захотят 
разбираться в том, как устроен человек, его тело и ду- 
ша. Сказанное относится и к компьютерам. Думаю, не 
ошибусь, если скажу, что девять десятых пользовате- 
лей персоналок уделяют значительно больше внима- 
ния не техническим подробностям устройства аппа- 
ратного обеспечения, а тому, насколько удобно им ра- 
ботать с техникой, выполняя свои сугубо прикладные 
задачи. Что называется — каждому свое. Вот тут-то и 
всплывает проблема, решение которой зачастую может 
повысить производительность работы с компьютером 
значительно больше, чем, скажем, применение нового 
микропроцессора. Речь идет о совершенных устройст- 
вах ввода информации (УВИ). Ведь их функциональ- 
ные и технические возможности и ограничения — это, 
по существу, функциональные и технические возмож- 
ности и ограничения всей системы в целом. И от того, 
насколько удобны эти устройства, как они выглядят, 
нравятся ли они нам, зависит и настроение пользова- 
теля, и в конечном итоге его производительность 
труда (последнее, по мнению классиков, самое 
главное, самое важное...). 

Компьютер информирует пользователя и (или) дру- 
гих потребителей (это могут быть, например, другие 
вычислительные системы) о результатах своей работы 


в форме цифровых кодов, принимающих форму гра- 
фических или текстовых изображений на экране дисп- 
лея, звуковых сигналов или даже механических воз- 
действий, но ничего в принципе не происходит до тех 
пор, пока пользователь не обратится к тому или иному 
УВИ и, таким образом, не заставит компьютер “услы- 
шат ь“ себя. 

Для построения УВИ используются различные при- 
нципы, но характерной их чертой является определен- 
ная специализация; устройство конкретного типа луч- 
ше всего приспособлено к вводу в машину информа- 
ции определенного характера. 

К наиболее распространенным компьютерным УВИ 
относятся клавиатуры, манипуляторы для управления 
курсором — типа мыши и трекбола, сканеры и систе- 
мы оптического распознавания символов (ОРС). Реже 
встречаются различного рода средства ввода графичес- 
кой информации (графические планшеты, диджитай- 
зеры), световые перья и сенсорные экраны, которые 
относятся к средствам специализированного назначе- 
ния. 

Рынок УВИ весьма разветвлен, и выпуском каждого 
типа устройств занимается большое число фирм. Од- 
нако устройства одного и того же типа, выпускаемые 
разными фирмами, различаются весьма незначитель- 
но. Клавиатуры относятся к устройствам универсаль- 
ного применения и чаще всего включаются в состав 
поставки компьютерной системы как ее неотъемлемая 
часть — при этом цена клавиатуры обычно включает- 
ся в цену системы. Мыши, которые уже приобрели на 
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рынке статус универсальных устройств (в дополнение 
к традиционной нише применений, каковой являются 
системы, работающие с графикой), также довольно 
часто предлагаются фирмами — поставщиками компью- 
терных систем — иногда в комплекте поставки ком- 
пьютера, но чаще за отдельную плату — как дополни- 
тельное устройство. 

Сканеры для считывания изображения, устройства 
ОРС, графические планшеты и другие 
специализированные УВИ обычно не 
рассматриваются в качестве главных 
средств ввода информации в компью- 
тер. Чаще всего это важный или просто 
полезный инструмент для выполнения 
специфических задач, прежде всего в 
издательских системах и системах авто- 
матизированного проектирования. Поэ- 
тому главными действующими лицами 
на рынке УВИ этих типов являются не 
производители компьютеров, а т.н. тре- 
тьи фирмы (под первой и второй пони- 
маются покупатель и продавец компью- 
тера). Исключение составляют лишь 
несколько крупнейших фирм — пос- 
тавщиков компьютерных систем, вклю- 
чая, прежде всего, ІВМ и НешІеИ- 
Раскагб. 

Клавиатуры 

Кто не знает, что такое клавиатура, 
поднимите руки. Я думаю, на лес под- 
нятых рук можно надеяться с весьма 
сомнительной долей вероятности, разве 
что где-нибудь на общем собрании пле- 
мени Мумба-Юмба. И хотя про клавиа- 
туры вместо меня с тем же успехом вам 
расскажет все необходимое каждый 
первоклассник, все же, для полноты из- 
ложения, кратко остановимся и на них. 

Ведь клавиатуры остаются главным 
средством ввода практически во всех 
задачах прикладного характера — элек- 
тронных таблицах и базах данных. Это 
ведущее положение они заняли еще со 
времен первого появления компьютеров. 

Нет, вернее, значительно раньше. 

Вспомните, ундервуды и ремингтоны. 

Но прогресс не стоит на месте, и вот 
на смену пишущим машинкам прихо- 
дят мощные текстовые процессоры, где 
клавиатура все также незаменима. А 


В техническом аспекте компьютерная клавиатура 
представляет собой совокупность простых 2-позицион- 
ных переключателей — либо механических кнопок, 
либо электронных бесконтактных, т.н. “мягких** пере- 
ключателей. При нажатии на клавишу происходит за- 
мыкание электрической цепи и в компьютер посыла- 
ется дискретный электрический сигнал. При этом сра- 
батывание переключателя каждой клавиши или опрс- 


Трекбол РС-Тгас 


Несмотря на сравнительно большие размеры, этот 
трекбол фирмы Міего ВреесІ удобен в работе. Форма 
его корпуса такова, что кисть и запястье во время 

работы находятся в том же 

положении, что и при манипу- 
лировании мышью. Устройство 
располагает тремя кнопками, 
из которых две внешние охва- 
тывают шар и поэтому очень 
удобно нажимать быстрыми 
прикосновениями, а на сред- 
ней есть выступ (букля), бла- 
годаря которому она (кнопка) 
легко нащупывается пальцем. 



Рс-Тгас можно без всяких хлопот включить в систе- 
му, располагающую программным обеспечением для 
мыши. В комплект поставки входит дискета с прог- 
раммой-утилитой Кеутар, резидентной программой 
для "привязки” двадцати широко распространенных 
прикладных программ, которые в оригинальных верси- 
ях работу устройств управления курсором не поддер- 
живают. 

Все опрошенные пользователи трекбола Рс-Тгас ука- 
зали в качестве основной причины своего перехода 
от мыши к трекболу то, что последний требует мень- 
ше места на столе, где стоит компьютер. Кроме то- 
го, пользователи говорят, что трекбол удобнее мыши. 
Им, в частности, легче рисовать на экране. Есть опыт 
использования описываемого устройства с графичес- 
кими пакетами -системами типа САПР и САИ (систе- 
мы автоматизированного проектирования и системы 
автоматизированного инжиниринга), а также с широко 
известной системой ѴІ^огсі Регіекі. 

Однако для целей САПР, для работы в системах 
коіиа 1-2-3, Оиаіго Рго и им подобных лучше подхо- 
дит близкий "родственник” трекбола Рс-Тгас — устрой- 
ство Раві-Тгар, у которого в верхней части корпуса 
кроме кнопок имеется колесико, дающее возможность 
маневрировать курсором в третьем измерении. Речь 
может, например, идти о перемещении по слоям мик- 
росхемы при работе в САПР, предназначенной для 
разработки ИС. 

Разрешающая способность устройства 200 срі. 
Цены: модель с последовательным интерфейсом — 

200 долл.; модель для компьютеров типа Р8/2 - 
119 долл. 


дальше — больше. Захотелось на ком- 
пьютере не только набрать текст, но и сверстать его, 
вставить туда картинки, которые, правда, либо рису- 
ются мышкой или трекболом, либо сканируются. Но и 
здесь в той или иной степени остается клавиатурный 
ввод. Так что, как ни крути, а без клавиатуры не 


деленных сочетаний переключателей нескольких одно- 
временно нажимаемых клавиш вызывает посылку в 
машину уникальных цифровых кодов. Существует нес- 
колько стандартизованных систем кодирования. 
Наиболее популярной в области персональных ком- 


о((ойтись. 


пьютеров (ПК) сейчас является система А5С1І 
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(Американский стандартный код для обмена информа- 
цией). 

Обычно компьютерная клавиатура содержит поряд- 
ка 60 клавиш с буквами, цифрами, знаками пунктуа- 
ции и другими символами, встречающимися в печат- 
ных текстах. В этой части клавиатуры отражается 
языковая принадлежность пользователя. Кроме того, 
клавиатуры имеют еще 30-40 клавиш, предназначен- 


ных для управления компьютером и исполнением 
программ. Эта часть клавиатуры от языковой принад- 
лежности пользователя не зависит. Сюда входят кла- 
виши управления курсором, функциональные клави- 
ши, клавиши ускоренного перемещения по экрану, 
клавиши для выдачи ряда специальных команд, вос- 
принимаемых аппаратными и программными средст- 
вами компьютера. 

Клавиатуры разных фирм — изготовителей различа- 
ются некоторыми сравнительно маловажными харак- 
теристиками, например, величиной усилия нажатия. 


наличием и величиной тактильной или звуковой об- 
ратной связи (под обратной связью в данном случае 
понимается уведомление пользователя о срабатывании 
переключателя — это может быть воспринимаемый 
пальцем щелчок или звук, который появляется при 
полном нажатии), наличием встроенных в клавиши 
световых индикаторов для отображения текущего сос- 
тояния переключателей. Кроме того, имеются разли- 
чия в габаритах клавиатур, размерах и 
расположении отдельных клавиш. 

Стандартная компьютерная клавиа-^ 
тура представляет собой плоский констг 
руктив толщиной примерно 50, длиной 
460 и шириной 200 мм. При конструи- 
ровании клавиатур, в зависимости от 
типа и (или) главного направления 
применения компьютера, реализуют 
различные варианты размещения кла- 
виш. Например, портативные компью- 
теры (лэптопы и ноутбуки) оснащаются 
более легкими, компактными клавиату- 
рами. Имеются и клавиатуры с сокра- 

— они приме- 
няются в магазинах, на складах, в пор- 
тах и Т.П., где критически важными яв- 
ляются размеры и вес устройства. 

В большинстве случаев клавиатуры 
являются взаимозаменяемыми: клавиа- 
туру от одного ПК можно подключить 
к другому. Исключение составляют кла- 
виатуры для ПК семейства МасіпІозЬ, 
которые отвечают требованиям уни- 
кального стандарта фирмы-изготовите- 
ля. 

Если говорить о ПК фирмы ІВМ, то 
системы кодирования, назначения и 
размещения клавиш на клавиатурах 
компьютеров класса ХТ и т.н. улуч- 
шенных клавиатурах машин классов 
АТ и РЗ/2 несколько различаются. 
Стандартная ХТ-клавиатура содержит 
84 клавиши, из которых 10 функцио- 
нальных и 17 клавиш цифровой клави- 
атуры. Улучшенная АТ-клавиатура со- 
держит 101 или 102 клавиши, в том 
числе 12 функциональных. Клавиши 
для ввода цифр и управления курсором 
конструктивно разнесены. 

Мыши и трекболы 

Мышь представляет собой еще одно широко распро- 
страненное УВИ, облегчающее пользователю работу со 
многими прикладными программными системами и 
делающее ее более простой и эффективной. В 
основной своей функции мышь является устройством 
управления положением курсора на экране монитора: 
перемещение мыши по гладкой поверхности (или по 
поверхности специального планшета) автоматически 


Трекбол Ехрегі Мойве 

Этот трекбол фирмы Кепяіпдіоп отличает малая 
площадь основания, и в то же время он имеет шар 
сравнительно большого диаметра. Двумя кнопками 

устройства, которые располо- 
жены вблизи от "ватерлинии” 



шара, легко пользоваться 
большим и безымянным паль- 
цами (или мизинцем); при 
этом самые длинные паль- 
цы — указательный и сред- 
ний — остаются свободными 
для манипулирования шаром. 

К настоящему времени име- 
ется только версия для ком- 
пьютеров типа Р8/2, но, безусловно, должна появить- 
ся и версия для машин типа Р8. Программное обес- 
печение, которое поставляется с устройством, дает 
возможность адаптировать его к требованиям конкрет- 
ного заказчика: менять местами кнопки (по их назна- 
чению) — это бывает необходимо, например, когда 
устройством должен будет пользоваться левша; эму- 
лировать работу 1-, 2- и 3-кнопочной мыши; опреде- 
лять режим работы одной из кнопок (возможны два 
режима: кратковременного нажатия и с фиксацией — 
т.е. западающей кнопки). 

Все эти изменения вы можете внести во время ус- 
тановки (инсталяции) программы — либо по подсказ- 
кам, выдаваемым в форме меню, либо путем ввода 
командных строк заданного формата. Программа обес- 
печивает также возможность пользоваться трекболом 
при работе с рядом распространенных программ, при 
разработке которых применение устройств управления 
курсором не предусматривалось. 

Те, кто имеет опыт эксплуатации этого трекбола (а 
они работали в среде таких программ, как Могіоп 
соттапбег, >Ѵіпбоаг/286, Ѵ\^Іпбоаг/386), отмечают 
удобные очертания его корпуса и удачное расположе- 
ние кнопок. 

Разрешающая способность устройства 200 срі. Цена 
модели для компьютеров типа Р8/2 - 169.95 долл. 


щенным числом клавиш 
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преобразуется в пропорциональное по величине и сов- 
падающее по направлению перемещение курсора по 
экрану. Встроенные в тело мыши клавиши позволяют 
пользователю подавать в ПК сигналы о том, что кур- 
сор достиг требуемого положения, и тем самым выби- 
рать те или иные объекты (например, пункты меню), 
перемещать их по экрану, вызывать одни объекты и 
убирать с экрана другие, а также эмулировать дейст- 
вие управляющих клавиш клавиатуры. 

Своей популярностью мышь обязана 
главным образом растущему спросу на 
прикладные графические программные 
системы, а также распространению гра- 
фического интерфейса пользователя, 
когда широко применяются мнемони- 
ческие изображения объектов — пикто- 
граммы. Возможности клавиатуры явно 
не согласуются с характером работы 
пользователя в такой **изоориентиро- 
ванной** среде. Поэтому и возникла 
потребность в другом средстве связи 
пользователя с компьютером. Самым 
популярным из различных модифика- 
ций этого средства оказалась мышь, ко- 
торая делает очень удобным манипули- 
рование такими широко распространен- 
ными в графических пакетах о(Ь>екта- 
ми, как окна, меню, кнопки, пикто- 
граммы. 

При конструировании мышей приме- 
няются механический, оптический или 
оптомеханический принципы действия. 

В корпусе механической мыши име- 
ется шар сравнительно большого диа- 
метра, который вращается, когда поль- 
зователь перемещает тело мыши по по- 
верхности стола. Шар приводит во вра- 
щение два ролика (ось вращения одно- 
го из них горизонтальна, второго — 
вертикальна). Те в свою очередь приво- 
дят в действие два механических де- 
шифратора, которые посылают свои 
выходные сигналы схеме интерфейса с 
мышью, имеющейся в компьютере. По- 
следняя обеспечивает перемещение 
курсора по экрану монитора. 

Оптомеханическая мышь отличается 
от механической только тем, что вместо 
механических дешифраторов использу- 
ются оптические, и сигналы посылают- 
ся ѣ компьютер в результате срабатыва- 
ния не механических, а бесконтактных 
оптических переключателей (т.е. сраба- 
тывающих при падении на них светово- 
го потока). 


ального планшета. Механическая и оптомеханическая 
мыши не требуют специального планшета — их мож- 
но перемещать по поверхности стола, по бумаге, стене 
и т.п. Однако они менее защищены от попадания пы- 
ли и грязи по сравнению с оптическими устройствами. 
В общем случае оптическая мышь более долговечна, 
но требует свободного места для размещения план- 
шета. 


трекбол Моизе>1гак 

Фирме ІТАС придется еще немало потрудиться, что- 
бы оправдать рекламу своего трекбола Моиае-ігак как 
"самого лучшего трекбола в мире". Во-первых, для 
его инсталяции требуется дос- 
таточио утомительная процеду- 
ра. Для того чтобы поставить 
эмулирующую программу Міс- 
гоаоН Мойве (либо аналогич- 
ную ей программу Мойве 8ув- 
іешв) или задать клик-кнопку 
необходимо выставить в за- 
данные положения несколько 
переключателей и перезапус- 
тить процессор кнопкой 

"гевеі". Боже вас упаси от попытки помейять местами 
назначение кнопок устройства — для этого его надо 
полностью разобрать. 

Удачной находкой в этом устройстве является спе- 
циальная площадка с подушечкой, на которой может 
при работе покоиться кисть руки. В то же время от 
манипулирования тремя маленькими неудачно распо- 
ложенными кнопками трекбола очень быстро устают 
пальцы. Хотя курсор перемещается по экрану доволь- 
но плавно, но все же рисовать трекболом трудно - 
даже при переключении его на самую малую ско- 
рость. 

Трекбол Моиве-Ігак поставляется с резидентной 
программой, которая выдает на^ экран меню, позволя- 
ющие пользователю работать в среде ДОС, в систе- 
мах Іоіив 1-2-? и Ѵіогб РегіесХ 4.2. 

Описываемый трекбол нашеіі применение на ряде 
рыболовецких судов — в составе поставляемой под 
ключ системы (на 386-ом процессоре) с пакетом 
программного обеспечения 8са РІоІ (на базе системы 
Ѵі^Іпсіовга), который предназначен для формирования 
электронных навигационных карт. В характерных для 
данного применения жестких условиях трекбол проя- 
вил себя очень хорошо. Использовать мышь на судах 
практически невозможно, во-первых, из-за качки, а 
во-вторых, из-за грязи, которой там всегда больше, 
чем достаточно. 

Разрешающая способность устройства 200 срі. 
Цены: 2-кнопочная модель с последовательным интер- 
фейсом и модель для компьютеров типа Р8/2 - 
169 долл.; аналогичная 3-кнопочная модель - 
179 долл.; 2-киопочная модель с параллельным интер- 
фейсом — 189 долл.; то же, но 3-кнопочная модель - 
195 долл. 



Оптическая мышь вообще не имеет движущихся 
частей. Перемещение воспринимается оптическими 
датчиками (встроенными в корпус устройства) в про- 
цессе их смещения относительно поверхности специ- 


Известны модели мышей, в которых есть возмож- 
ность менять соотношение скоростей перемещения 
мыши и курсора — это т.н. мыши динамического дей- 
ствия. В некоторых случаях реализовано такое реше- 
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ние: первые 1-2 дюйма перемещения мыши 

(1 дюйм = 25,4 мм) вызывают медленное, “тонкое** 
смещение курсора, а дальнейшее перемещение приво- 
дит ко все более непропорциональному ускорению 
движения последнего. Есть модели с постоянным, но 
задаваемым извне соотношением перемещений, т.е. 
есть возможность устанавливать величину этого па- 
раметра при настройке программного пакета, с кото- 


рым предполагается работать в данный период вре- 
мени. 

Мыши обычно оснащаются одной, двумя или тремя 
кнопками, на которые пользователь может нажимать 
либо кратковременно, либо длительно. При этом в 
компьютер посылаются сигналы, уведомляющие его о 
том или ином решении пользователя. Одна из кнопок 
(она обязательна) служит для фиксации выбора поль- 
зователем того или иного объекта на экране монитора. 
Вторая и третья кнопки (если они поддерживаются 
аппаратными и (или) программными средствами ком- 
пьютера) могут использоваться для эмуляции клавиш 
клавиатуры или выполнения других функций. Однако 
стандартов на аппаратно-программное обеспечение 
мышей до сих пор нет. Это означает, с одной стороны. 


что ряд прикладных программных систем ориентиро- 
ван только на 1 -кнопочные мыши, а с другой, что воз- 
никают серьезные трудности при попытке “привязать** 
мыши некоторых моделей к тем или иным приклад- 
ным программным системам. 

Что касается интерфейса с мышью, то он реализу- 
ется в двух вариантах: 1) сама мышь поставляется как 
неотъемлемая часть компьютера — в этом случае ни- 
каких дополнительных средств к ком- 
пьютеру не требуется (такого решения 
придерживается фирма Арріе в своем 
семействе ПК МасіпІозН; 2) мышь пос- 
тавляется как отдельное средство. По 
последнему пути идет фирма ІВМ. В 
этом случае интерфейс может прини- 
мать форму стандартного последова- 
тельного порта; специальной платы- 
адаптера, устанавливаемой в гнездо 
расширения ввода-вывода; специальной 
платы-адаптера, которая устанавлива- 
ется в полу разъем-соединитель для кла- 
виатуры и имеет полуразъем для под- 
ключения последней. Для пользователя, 
с точки зрения функциональных воз- 
можностей и качества работы мыши, 
все эти варианты равноценны. 

Хотя никаких официальных стандар- 
тов на мыши до сих пор не разработа- 
но, де-факто на рынке существуют три 
стандарта, которым фирмы — изгото- 
вители мышей всячески стремятся сле- 
довать. Речь идет о мышах фирм Міс- 
гозоП, Ео^іІесН и Моизе Бузіет ^ они 
относятся к наиболее популярным изде- 
лиям этого рода, к тому же поддержи- 
ваемых большинством прикладных 
программных систем. 

Очень часто мыши поставляются со 
специальными программами — генера- 
торами меню. Такая программа позво- 
ляет пользователю создавать на экране 
одно или несколько меню и “начинять** 
их пункты командами управления дру- 
гими программами. После установки 
курсора на том или ином пункте и нажатии на клави- 
шу мыши программа направляет соответствующей 
прикладной программе указанную в меню команду — 
точно так же, как если бы эта команда была введена с 
клавиатуры. 

Трекбол аналогичен мыши и по принципу действия, 
и по функциям; различаются они, по существу, только 
конструктивно. Трекбол представляет собой перевер- 
нутую на спину мышь, шар оказывается сверху, и 
пользователь должен вращать его ладонью или паль- 
цами, а перемещать корпус устройства не надо. 

Мышь или трекбол? Иногда ответ совершенно одно- 
значен, но чаще это дело вкуса. И как всегда крите- 
рий истины — опыт. Если пока нет своего, то стоит 
обратиться к чужому. Каковы же мотивы тех пользо- 


Трекбол Тгаскег Моиее 

Это устройство рекламируется изготовителем фир- 
мой Реппу апсі Оііеа как единственный трекбол ”на 
котором можно считать**, имея в виду то, что в его 

корпус встроен калькулятор 
(запитываемый от солнечной 
батареи). Никакой функцио- 
нальной интеграции этого 
калькулятора с собственно 
трекболом не просматривает- 
ся. 

В то же время сам трекбол 
вполне на уровне: удачны 

пропорции корпуса и шара, 
хорошо расположены кнопки. 
Размеры корпуса таковы, что пользователь легко мо- 
жет взять его одной рукой, перемещать шар мягкой 
частью указательного пальца и, не меняя положения 
руки, нажимать на фиксирующую выбор кнопку паль- 
цами, охватывающими корпус. 

Трекбол Тгаскег Мойве поставляется с программой 
КеуВаІІ, которая позволяет использовать его с любой 
не ориентированной на мышь текстовой программой, 
но назначение функций кнопок надо программировать 
самому пользователю, что является достаточно трудо- 
емким делом. 

Устройство с успехом применено в медицинской ап- 
паратуре, поставляемой фирмой 08ѴѴ сотриѣег, кото- 
рая заменила калькулятор цифровым клавишником. 
Главная причина успеха трекбола в этом применении 
в том, что медики как огня боятся клавиатуры, а 
трекбол в модифицированном варианте ее практичес- 
ки заменяет. 

Разрешающая способность устройства 200 срі. Цены 
модели с последовательным интерфейсом для ком- 
пьютеров типа РС и Р8/2 - 99 долл. 



4 За к. 2399 


КомпьютерПресс 9'91 




26 


УСТРОЙСТВА ВВОДА ИНФОРМАЦИИ 


вателей персональных компьютеров (ПК), которые от* 
казываются от такого распространенного устройства 
управления курсором, как мышь, в пользу шарового 
манипулятора, трекбола? Приверженцы трекболов 
приводят следующие три аргумента: 

1. Трекбол управляет курсором точнее. И вот поче- 
му. Во-первых, даже у самого маленького трекбола ди- 
аметр шара больше, чем у мыши, а чем больше шар, 
тем проще им манипулировать. Во-вто- 
рых, ладонью и пальцами удается рабо- 
тать точнее, чем кистью и запястьем, 
как в случае мыши. Поэтому в приме- 
нениях, где приходится иметь дело с 
мелкими деталями, например, в систе- 
мах автоматизированного проектирова- 
ния, при разработке электрических 
схем, трекбол — вещь незаменимая. 

2. Трекбол занимает меньше места 
на столе пользователя. Дело в том, что 
когда работаешь с трекболом, надо 
только вращать его шар, а корпус уст- 
ройства, в отличие от мыши, остается 
неподвижным. Это свойство делает 
трекболы идеальным средством для раз- 
личного рода пультов. Чаще всего речь 
идет о встраивании трекбола в поверх- 
ность моторного поля пульта. В част- 
ности, трекболы широко используются 
авиадиспетчерами для указания объек- 
тов на экранах радаров, в автоматизи- 
рованных системах управления техно- 
логическими процессами (АСУ ТП) и 
т.п. По той же самой причине трекбо- 
лы должны стать неотъемлемой прина- 
длежностью портативных компьютеров. 

Последняя тенденция будет определять- 
ся тем, как быстро удастся реализовать 
на машинах этого класса работу с гра- 
фикой, для которой критически важно 
управление курсором при помощи ма- 
нипулятора. 

3. Трекбол не нуждается в тщатель- 
ном уходе. В случае мыши ее обрези- 
ненный шар все время контактирует с 
поверхностью стола и собирает с нее 
пыль и грязь, что отрицательно сказы- 
вается на работе устройства. Когда же речь идет о 
трекболе, то до шара дотрагиваются только ладонью и 
пальцами, поэтому чистить его можно значительно 
реже. 

Несмотря на внешние различия трекбол и мышь 
конструктивно очень похожи — при вращении шар и 
в том и в другом устройстве приводит во вращение па- 
ру колесиков. Одно из них перемещается, когда шар 
вращается вокруг оси, соответствующей вертикальному 
смещению курсора по экрану, второе — когда он 
(шар) вращается вокруг оси, соответствующей гори- 
зонтальному смещению курсора. Путем подсчета элек- 


трических импульсов, возникающих при повороте ко- 
лесика на заданный угол (шаг), программное обеспе- 
чение, поддерживающее работу трекбола, отображает 
вращательное движение шара перемещением курсора 
по экрану. 

Мерой главной, коренной характеристики трекбола 
(как и мыши) является число отсчетов, даваемых упо- 
мянутым колесиком на единицу хода шара — срі 


(соипіз Рег ІпсН — число отсчетов на дюйм). Этот па- 
раметр определяется количеством зубьев (или других 
элементов) колесика, при прохождении которых через 
датчик и формируется выходной импульсный сигнал. 
Чем больше количество таких элементов на колесике, 
тем больше величина показателя срі и, следовательно, 
выше точность позиционирования курсора. 

Изготовители часто характеризуют трекболы другим 
показателем — числом точек на единицу хода ша- 
ра — брі (Ооіз Рег ІпсН — число точек на дюйм). По 
названию он совпадает с показателем, характеризую- 
щим мониторы и лазерные принтеры, но по существу 
это не одно и то же. Если для принтера брі означает 


Трекбол Тгаск Мал 

Этот трекбол фирмы ^одиесІ 1 имеет довольно нео- 
бычную конструкцию: шар расположен с левой сторо- 
ны прямоугольного корпуса, а клавишный узел (в нем 
3 кнопки) — с правой. Это 
предполагает, что манипулиро- 
вать шаром можно только 
большим пальцем правой ру- 
ки. На первый взгляд, конст- 
рукция представляется удач- 
ной: шаром (он имеет сравни- 
тельно небольшой диаметр) 
очень легко управлять (прав- 
да, это относится только к 
работе в среде текстовых про- 
цессоров, но тонкого позиционирования курсора, ко- 
торое необходимо для чертежных и рисовальных паке- 
тов, добиться при таком шаре нельзя), однако когда 
работать приходится долго, большой палец устает и 
точность управления курсором теряется. Кроме того, 
трекбол совершенно не годится для левшей (если не 
считать тех, у кого очень развиты мизинцы). 

Тгаск Мап поставляется с программой Мойве \Ѵаге, 
которая выдает меню, позволяющее работать более 
чем с 24 не ориентированными на мышь программа- 
ми, и программой код! Мепи, которая дает возмож- 
ность пользователям адаптировать вышеупомянутые 
меню или создавать свои собственные. В состав этой 
программы включена программа Мойве 2-3, выдающая 
шаблон для пользования системой коіив 1-2-3 в вер- 
сиях 1 и 2. 

Есть удачный опыт применения этого трекбола с 
пакетами САПР, текстовыми процессорами. Особенно 
положительно он проявил себя при работе в рисо- 
вальных пакетах, где им легче управлять курсором, 
чем мышью. 

Разрешающая способность устройства 300 срі. Це- 
ны: модель с последовательным интерфейсом - 

139 долл.; модель с параллельным интерфейсом — 
149 долл. 
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количество точек, которое устройство может размес- 
тить на единице длины (1 дюйм) бумаги, то в случае 
трекбола речь идет о том, насколько смещается курсор 
на экране (а смещение измеряется числом экранных 
точек) при повороте шара на 1 дюйм. Этим показате- 
лем и оценивается скорость работы трекбола. 

Показатель брі неоднозначен. Дело в том, что прог- 
раммы обслуживания трекболов могут масштабировать 


отсчет колесиков. В результате 1 -дюймовый ход шара 
может быть преобразован в смещение курсора, изме- 
ряемое числом точек в диапазоне от 50 до 15000 (т.е. 
от 1/6 до 50 дюймов на экране дисплея типа ѴСА). 
На практике большинство программ-драйверов трекбо- 
лов имеют характеристику, именуемую динамическим 
ускорением. Это коэффициент, обеспечивающий авто- 
матическое варьирование дрі. Это означает, что при 
быстром повороте шара курсор пройдет на экране зна- 
чительно большее расстояние, чем при медленном по- 
вороте, даже если ход шара в обоих случаях будет 
одинаковым. 

Конечно, возможность перемещать курсор на боль- 
шие расстояния, превышающие размеры экрана, пред- 
ставляется совершенно бесполезной. Но фирмы, ука- 


зывающие соответствующие высокие показатели ёрі 
для своих изделий, имеют в виду, что в этом случае 
вы можете одним коротким, но быстрым движением 
шара, переместить курсор на весь экран. 

При нормальной работе такие высокие значения ёрі 
роли не играют. Главным показателем трекбола все же 
остается величина срі. Именно ею оценивается точ- 
ность позиционирования курсора. У подавляющего 
большинства известных моделей трек- 
болов этот показатель находится в пре- 
делах 200-300 срі. 

В отличие от мышей трекболы наде- 
ляются одной особой функцией — фун- 
кцией фиксации кнопки, служащей для 
подтверждения того, что курсор приве- 
ден в требуемую точку. Такая кнопка 
имеется во всех устройствах управле- 
ния курсором; ее именуют клик-кноп- 
кой — от слова “с1іск“, означающего 
кратковременное нажатие, нажатие 
быстрым касанием. Функцию фиксации 
клик-кнопки называют также функци- 
ей управления протяжкой курсора. На- 
личие этой функции дает вам возмож- 
ность (в случае мышей это не предус- 
матривается) рисовать, например, ли- 
нию или перемещать выбранный на эк- 
ране объект без того, чтобы держать 
все время нажатой кнопку устройства. 
Для трекболов это совершенно необхо- 
димое свойство, так как нажимать на 
кнопку и одновременно вращать шар- 
манипулятор сколь-нибудь длительное 
время практически невозможно. 

Трекболы могут работать с большин- 
ством программ, ориентированных на 
управление мышами (т.е. характеризу- 
ются совместимостью в этом аспекте). 
Для работы с популярными программа- 
ми, которые не предусматривают при- 
менение устройств управления курсо- 
ром (как, например, первые версии 
системы Ьоіиз 1-2-3), поставляются 
специально разработанные драйверы. 
При этом обычно предоставляется возможность адап- 
тировать работу трекбола (в сравнительно малознача- 
щих деталях) к собственным потребностям. Речь идет, 
например, об эмуляции (т.е. воспроизведении) работы 
1-, 2-, 3-кнопочной мыши или о том, чтобы поменять 
местами назначение кнопок — чтобы правая выполня- 
ла функцию левой и наоборот (последнее может по- 
требоваться, когда трекбол куплен левшой). 

Сканеры и устройства ОРС 

В связи с растущей популярностью систем настоль- 
ных издательств и широким применением компьютер- 
ных (электронных) документов, в которых текстовый 
материал перемежается графикой (схемами, рисунка- 


Трекбол Рс ТгаскЬаІІ 

Среди начинающих пользователей, когда они берут- 
ся за мышь или трекбол, распространен вопрос: ”А 
мне от этого хуже не станетУ* В случае устройства Рс 

ТгаскЬаІІ фирмы Мойве Зув- 
іетв ответ такой: ”Да, ста- 

нет”. Дело в том, что его 
разработчики, по-видимому, 
считают, что у большинства 
людей рука имеет либо очень 
длинный большой и очень ко- 
роткие остальные пальцы, ли- 
бо наоборот — большой палец 
короткий, а остальные очень 
длинные. Шар удобнее всего 
вращать вытянутым указательным, пальцем, но при 
этом большой палец не дотягивается до левой кноп- 
ки. Чтобы было удобно нажимать на нее приходится 
все время работать согнутым указательным пальцем, 
отчего он быстро устает. 

Неудачная конструкция описываемого трекбола не 
способствует и той тонкой координации движений при 
работе шаром и кнопками, которая необходима при 
управлении курсором. Из-за этого нередки случаи, 
когда пользователь нажимает на кнопку фиксации вы- 
бора преждевременно со всеми вытекающими из это- 
го последствиями. 

Рс ТгаскЬаІІ поставляется с программой-драйвером, 
которая выдает на экран меню, облегчающее пользо- 
вание рядом программ, не ориентированных на при- 
менение мыши. Кроме того, поставляется пакет гра- 
фики и рисования РгеэепіаІІоп Мадісіап. 

Разрешающая способность устройства 200 срі. 
Цены: модель с последовательным интерфейсом и 

модель для компьютеров типа Р8/2 — 119 долл.; мо- 
дель с параллельным интерфейсом — 139 долл. 
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ми и Т.П.), важнейшим средством ввода в компьютер 
для последующей обработки больших объемов данных 
и (или) изоинформации становятся сканеры и устрой- 
ства ОРС. Их привлекательность постоянно растет в 
силу быстрого падения цен как на серийные изделия 
этого класса, так и на персональные компьютеры, 
обеспечивающие эффективное считывание графичес- 
ких изображений. 

Сканер изображений и устройство 
ОРС можно представлять себе как свое- 
го рода фотоаппарат, который делает 
“снимок“ того, что изображено на бу- 
маге. Однако после щелчка затвора та- 
кого фотоаппарата изображение не по- 
падает на фотопленку, а преобразуется 
в поток цифровых сигналов. Через ин- 
терфейсную плату, установленную в 
гнезде ввода-вывода, эта изоинформа- 
ция поступает в компьютер и преобра- 
зуется в файл особого формата. Затем 
этот файл обрабатывается соответству- 
ющим программным обеспечением. В 
отношении графической информации 
(рисунки, схемы, фотографии), целью 
обработки является модификация (на- 
пример, изменение масштаба, ретуши- 
рование), а информация, представляю- 
щая алфавитно-цифровые символы, 
преобразуется в текстовую форму, в ко- 
торой ее можно редактировать, распе- 
чатывать и т.п. 

Эти средства целесообразнее всего 
использовать, когда на компьютере не- 
обходимо обработать большой объем 
информации. В этом случае сканирова- 
ние позволяет отказаться от необходи- 
мости повторно набивать отпечатанный 
ранее (на пишущей машинке или типо- 
графским способом) текстовый мате- 
риал. 

Центральным элементом любой ска- 
нирующей системы является датчик, 
воспринимающий световой поток, кото- 
рый отражается от поверхности бумаги 
со считываемым материалом. В некото- 
рых сканерах считываемая страница 
кладется на планшет (так же, как во 
многих копировальных аппаратах), а в 
других протягивается через зону вос- 
приятия датчика. В любом случае дат- 
чик сканирует страницу по всей ее ши- 
рине с шагом 1/100 или 1/200 дюйма (1 дюйм = 
25.4 мм). В процессе сканирования страница предста- 
вляется последовательностью строк (линий), каждая 
из которых составляется из темных и светлых точек- 
пятен. Эти точки рассматриваются как единичные 
элементы изображения- пиксел и (ріхеіз) и вводятся в 
компьютер в форме непрерывного потока цифровых 
(дискретных) сигналов. Поскольку сканирование всег- 


да выполняется стандартизированным способом, то на 
основе упомянутых сигналов графический образ стра- 
ницы можно в любое время восстановить с целью, 
например, отображения на экране или воспроизведе- 
ния при помощи печатающего устройства. Такой циф- 
ровой образ можно также обрабатывать при помощи 
графики. Например, этим способом можно воспроиз- 
водить свою личную подпись под письмами и доку- 


ментами. Для этого ее достаточно просканировать и 
занести на хранение в компьютер. 

ОРС предполагает определенную обработку — пре- 
образование результата сканирования специальной 
программой, которая ставит в соответствие, составлен- 
ному из вышеупомянутых точек рисунку алфавитно- 
цифрового символа, его стандартный компьютерный 
код. После такого преобразования получается тексте- 


Трекбол ТгаскЬаіІ 

Устройство ТгаскЬаіІ фирмы Іупх сотриіег Ргосіисіа 
может показаться несколько примитивным, но это 
только внешнее впечатление — фирма сделала очень 
много, чтобы получилась дей- 
ствительно уникальная вещь. 

Во-первых, для измерения хо- 
да колесиков, на которые пе- 
редается вращение шара, при- 
менены не светодиоды, как 
это сделано в большинстве 
трекболов, а своего рода ма- 
ленькие "щетки”, которые вос- 
принимают, на сколько шагов 
(зубьев) повернулось 

колесико. Это решение не повлияло на качество 
работы устройства, но позволило применить более 
простую электронную схему, в результате фирма 
смогла пойти на то, чтобы давать гарантию на более 
длительный, чем другие срок службы устройства. 

Еще более полезным новшеством является комплек- 
тация трекбола съемным интерфейсным блоком, вы- 
полненным в виде корпуса-коробочки, который встав- 
ляется (при помощи полуразъемов) в провод, соеди- 
няющий трекбол с компьютером. Это дает возмож- 
ность, меняя этот блок (а он стоит всего 

29.95 долл.), использовать один и тот же трекбол с 
машинами разных типов (фирм Арріе и ІВМ). 

Описываемое устройство одинаково удобно и для 
правшей и для левшей. Только, когда приходится де- 
лать длинные протяжки курсора по экрану, возникает 
ощущение, что лучше было бы это делать не одной, 
а двумя руками. 

Трекбол поступает с программой, выдающей меню 
для работы в ДОС, с системами Ьоіиа 1-2-3 и Ѵіогб 
РегіесХ. Он получил положительные отзывы ряда поль- 
зователей, которые особо отметили точность и ста- 
бильность позиционирования курсора, что крайне важ- 
но при работе в среде САПР печатных плат, где при- 
ходится иметь дело с мелкими деталями. 

Разрешающая способность устройства 200 срі. Це- 
ны: модели с последовательным и параллельным ин- 
терфейсами — 129 долл.; интерфейсные блоки для 

компьютеров РС, РЗ/2, АрІІе 2 и МасіпІосЬ - 

29.95 долл, (каждый). 
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вый файл, с которым могут работать системы обработ- 
ки текстов (текстовые процессоры), системы типа 
электронных таблиц и баз данных. 

Как разновидность ОРС можно рассматривать фак- 
симильные устройства ввода. Главное их различие в 
том, что в случае ОРС сканированное изображение 
поступает в компьютер по кабелю от рядом стоящего 
сканера, а в факсимильной системе сканер может на- 


том же случае, когда речь идет о вводе изоинформа- 
ции, альтернативы сканированию просто нет. 

V 

другие устройства ввода 

Клавиатуры, мыши и трекболы стали, по существу, 
унифицированными средствами ввода, которые широ- 
ко используются практически во всех направлениях 


Трекбол ПоІІег Моизе 

Этот трекбол (фирма СН Ргосіисіа) отличается боль- 
шим шаром (размерами с бильярдный) и наличием 
четырех крупногабаритных кнопок. Йо практика пока- 
зала, что крупные элементы — 
это еще не все, что надо для 
того, чтобы получился удоб- 
ный в пользовании трекбол. 
Вращать шар кончиками паль- 
цев так же неловко, как пы- 
таться ими касаться внутрен- 
ней стороны ладони, а если 
вращать его ладонью, то те- 
ряется контакт с кнопками. 
Правда, последний недостаток 
несколько сглаживается наличием кнопок с фиксацией 
(т.е. западающих при нажатии), но такое решение 
противоречит принципу "безрежимного” действия, сог- 
ласно которому нежелательно требовать от пользова- 
теля выполнения дополнительной операции выбора 
режима работы устройства. Слишком тугие кнопки и 
неудачное их размещение приводят к тому, что 
быстро устает большой палец, которым их приходится 
нажимать. 

Трекбол поставляется с программой, которая выдает 
меню для работы в ДОС, в среде ^оіи8 1-2-3 и УМогб 
РегіесХ 4.2. Есть возможность создавать и собствен- 
ные меню. 

Несмотря на все свои недостатки, описываемый 
трекбол благодаря весьма высокой точности позицио- 
нирования курсора, получил довольно хорошую оценку 
у ряда пользователей, которые накопили опыт работы 
с ним в среде систем ѴѴогсі Регіесі 5.1, Оиаіго Рго и 
АиЮСАО. 

Разрешающая способность: номинальное значение 

200 срі, возможна установка (при помощи переключа- 
телей) уровней 100 и 400 срІ. Цены: модель с после- 
довательным интерфейсом и для компьютеров типа 
РЗ/2 — 129,95 долл.; модель с параллельным интер- 
фейсом — 149,95 долл. 


г 



применений компьютерной техники. 
Довольно широко в последнее время 
стали применяться сканеры и системы 
ОРС. Однако остаются довольно боль- 
шие категории пользователей, которые 
работают в условиях, требующих спе- 
циализированных средств ввода инфор- 
мации в компьютер. 

Графические планшеты и диджитай- 
зеры предполагают большую степень 
участия пользователя в процессе ввода. 
Это в большой мере устройства меха- 
нического действия. Графический план- 
шет содержит пластину, на поверхнос- 
ти которой пользователь рисует специ- 
альным карандашом. В пластину встро- 
ены датчики, которые фиксируют теку- 
щее положение острия и передают со- 
ответствующий сигнал (предварительно 
преобразованный в цифровую форму) в 
компьютер. Последовательность поло- 
жений острия можно запомнить в па- 
мяти компьютера и затем выдать на эк- 
ран дисплея в виде изображения линии. 
При этом возможен вариант формиро- 
вания изображения в режиме реального 
времени, т.е. практически одновремен- 
но и в том же темпе, в каком рисует 
пользователь. 

Другой подход к преобразованию пе- 
ремещения рисующего инструмента в 
цифровой код реализуется в планшет- 
ном устройстве с движущейся держав- 
кой — “рукой“. В этом случае датчики 
непрерывно фиксируют положение 
этой руки. В процессе рисования (или 
обводки готового рисунка осуществляет- 
ся передача в компьютер цифровых ко- 


ходиться на большом расстоянии от компьютера и ин- 
формация поступает по линии телефонной связи. 

Еще несколько лет назад сканеры стоили не 
меньше 25 тыс. долл., а сейчас цены даже на самые 
высококлассные устройства, например, модели Зсапіеі 
фирмы НешПеи-Раскагб, существенно ниже 2 тыс. 
долл. Программное обеспечение ОРС поставляется 
либо вместе со сканерами, либо как отдельный 
продукт и стоит порядка нескольких сотен долларов. 
При таких ценах применение систем ОРС 
экономически вполне оправдывается, когда речь идет о 
вводе текстов объемом порядка 1000 стр. и больше. В 


дов — координат точек рисунка. 

Третий способ оцифровки изображений или переме- 
щения рисующего инструмента сводится к использова- 
нию стандартной видеокамеры, подключаемой к ком- 
пьютеру через специальную интерфейсную плату, ко- 
торая размещается в корпусе последнего. В этом слу- 
чае видеоизображение, последовательность дискретных 
сигналов, представляющих в стандартизованном фор- 
мате точки, составляющие снимаемый рисунок, преоб- 
разуется специальной программой в стандартизован- 
ное цифровое “компьютерное изображение**. По- 
лученные изображения можно затем обрабатывать при 


КомпьютерПресс 9'91 






30 


УСТРОЙСТВА ВВОДА ИНФОРМАЦИИ 


кНГЕРКВ^^РО 

СОВЕТСКО-ФРАНКО-ИТАЛЬЯНСКОЕ ПРЕДПРИЯТИЕ 

У Вас есть желание и возможность 
идти в ногу с прогрессом? 

СП “Интерквадро” поможет Вам 
воплотить их в реальность! 

“Интерквадро” разрабатывает 
и поставляет: 

□ программно-технические комплексы АСУ ТП 
для нефтехимической, металлургической 

и других отраслей щюмыпіленности; 

□ системы автоматизации учреждений и управлен- 
ческой деятельности; 

□ автоматизированные городские и учрежденчес- 
кие телефонные станции и ^эедства телекомму- 
никации фирмы **А1саіеГ*; 

□ распределенные информационно-справочные 
системы на базе **Міпі(еГ*; 

□ системы, приборы и технологии в области эко- 
логии промышленного производства (измери- 
тельно-информационные комплексы контроля 

и анализа, ^>едства и технологии снижения вред- 
ных выбросов); 

□ настольно-издательские системы; 

□ геоинформационные системы для решения за- 
дач городского планирования 

и земельного кадастра; 

□ локальные вычислительные сети на базе персо- 
нальных и супермикроЭВМ; 

□ широкий спектр вычислительной техники 
и периферийного оборудования. 

Ваши специалисты могут пройти обучение в 
нашем учебном центре “Элитарекс”, 
а также технических центрах наших партне- 
ров во Франции, Англии и Г олландии, 

ИНТЕРКВАДРО является бизнес-партнером 
и представляет в СССР продукцию фирм 
ЗсЫитЬегдег, Когіех, Напк Хегох, Сапоп и 
других, а также 

осуществляет поставку за рубли 
программных средств 
корпорации 

ВогГапсІ 

Остановив свой выбор на 
ИНТЕРКВ АДРО, 

Вы поступили совершенно правильно! 

СССР, 125130, Москва, 

2-й Новоподмоскоеный пер., 4 
Телефон: 15092 01 Телефакс: 9430059 
Телекс: 413560 Телетайп: 207321 


помощи обычных графических пакетов прикладного 
программного обеспечения. 

Световые перья и сенсорные экраны считается це- 
лесообразным применять в ситуациях, когда клавиату- 
рный ввод слишком труден для пользователя или от- 
нимает у него много времени и когда имеется прог- 
раммное обеспечение, поддерживающее возможность 
выбора пользователем некоторых вариантов, отобража- 
емых на экране. 

Известно много разновидностей технических реше- 
ний, реализующих принципы светового пера и сенсор- 
ного экрана. Одно из них сводится к тому, что перо 
воспринимает световой поток, излучаемый экраном 
дисплея. Поскольку каждая точка экрана периодичес- 
ки регенерируется (т.е. подвергается действию элект- 
ронного луча), компьютер может установить, к какой 
точке экрана подведено световое перо, определив мо- 
мент времени, когда перо прореагировало (сигналом 
на своем выходе) на возникающее при регенерации 
повышение яркости экрана в точке касания. 

Другой подход состоит в том, чтобы создать перед 
экраном своего рода завесу, сеть из сфокусированных 
световых лучей. Когда световое перо (или другой объ- 
ект, например, карандаш) приближается к экрану, 
происходит прерывание нескольких лучей завесы. Ко- 
ординаты точки касания можно определить по номе- 
рам прерванных лучей (по горизонтали и вертикали) с 
отсчетом их от угловой точки экрана. Далее компью- 
тер определяет, какой элемент текущего изображения 
на экране имеет данные координаты, и выполняет 
приписанное этому элементу действие. 

Третий подход связан с помещением перед экраном 
или за ним двух электрически заряженных сеток. При 
касании экрана пальцем или каким-то предметом про- 
исходит сближение этих сеток и формируется элект- 
рический сигнал, декодируя который компьютер мо- 
жет определить координаты точки касания. Во всех 
случаях программное обеспечение компьютера исполь- 
зует полученную информацию о координатах задейст- 
вованного элемента изображения точно так же, как 
если бы речь шла о нажатии клавиши, и начинает вы- 
полнять запланированное для этой ситуации действие 
или вариант. 

Рынок УВИ, по существу, делится на несколько от- 
дельных секторов, что отражает различную степень 
популярности и различный спрос на компьютерные 
устройства ввода. При этом все нарастающая 
тенденция к оснащению компьютером каждого 
рабочего места будет означать сохранение большого 
спроса на клавиатуры. Хотя будет продолжаться рост 
популярности мышей, и во многих случаях эти 
устройства станут обязательной принадлежностью 
компьютеров, все же заменить они клавиатуры не 
смогут. 

Дело в том, что еще не изобретен компьютер, на 
котором можно было бы работать только мышью, и в 
то же время большинство компьютеров прекрасно ра- 
ботают только с клавиатурой, без мыши. 
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Сканеры и системы ОРС останутся сравнительно 
специализированными средствами, но потребность в 
них по мере того, как ввод изоинформации в компью- 
тер будет в глазах пользователей приобретать ту же 
важную роль, что и представление информации в гра- 
фической форме на выходе, очевидно, будет возрас- 
тать. Графические планшеты и диджитайзеры, свето- 
вые перья и сенсорные экраны будут оставаться в сво- 
их сравнительно узких рыночных нишах. Некоторые 
из этих устройств станут чрезвычайно важными аппа- 
ратными средствами для весьма небольшого количест- 
ва пользователей, но подавляющему большинству по- 
добного рода экзотика вряд ли потребуется. 

В настоящее время цены на клавиатуры и мыши 
достаточно малы. Хорошую клавиатуру можно купить 
примерно за 50-150, а мышь — за 35-125 долл. Даль- 
нейшее падение цен представляется маловероятным. 

Спрос на сканеры, в том числе и в составе систем 
ОРС, должен повышаться в связи с совершенством 
техники работы с графикой и падением цен на модули 
графических процессоров. Самые высококлассные по 
быстродействию и разрешающей способности сканеры 
стоят в розницу больше 10 тыс. долл., но есть вполне 
приличные модели, которые можно приобрести всего 
за 1 тыс. долл, и даже дешевле, а ручные сканеры 
(устройства, в которых сканирующий узел надо пере- 
мещать вручную) стоят меньше 500 долл. 

Ожидать падения цен на графические планшеты, 
диджитайзеры, световые перья, сенсорные экраны и 
другие специализированные УВИ не приходится, пос- 
кольку тенденции к увеличению спроса на них не 
просматривается. 

В стадии исследований и конструктивных разрабо- 
ток в настоящее время находится еще ряд новых уст- 
ройств ввода. Наиболее примечательными из них яв- 
ляются системы распознавания речи (которые можно 
“научить** слышать и интерпретировать произносимые 
вслух команды и данные) и т.н. “программные** кла- 
виатуры. Последний подход предусматривает отобра- 
жение клавиатуры на экране и отказ от аппаратных 



переключателей и клавиш. Разработчики активно про- 
пагандируют эти устройства, добиваясь организации 
их серийного производства. Утверждается, что они, 
благодаря своим уникальным свойствам, будут способ- 
ствовать выходу компьютеров на новый, значительно 
более высокий уровень гибкости. 

Тем не менее не вызывает сомнений, что в ближай- 
шие 5 лет основным средством ввода для компьютеров 
останутся все те же старые, добрые механические кла- 
виатуры. Их простота, надежность, дешевизна и при- 
вычность таковы, что пройдет еще много лет, прежде 
чем возникнет угроза их доминирующему положению 
со стороны **конкурентов**. 

Г, Берг 

По материалам: 

Раиікпег ТесЬпісаІ К.ерогІ8 оп Місгосотриіегз апд 
ЗоПдѵаге; 

ОаІаРго Керогіз оп Місгосотриіегз. 

Р.'^аііасе, АН Ніе гі^Ы тоизе. РС СотриГш^, Іипе, 
1990. 


Советско-нидерландское совместное предприятие «ЭЛ КОМ» представляет новое программное средство: 




80РТКЕУІ 


СИСТЕМА ЗАЩИТЫ ФАЙЛОВ от несанкционированного доступа и копирования 
на ІВМ РС. ХТ, АТ, Р5/2 компьютерах 


Система 50РТКЕУ позволяет защищать как файлы, содержащие данные (текстовые, базы данных, коммер- 
ческую информацию и пр.), так и выполнимые файлы (ЕХЕ и СОМ формата). При помощи системы можно: 

• защитить данные от несанкцио- • организовать защиту распрост- 
нированного тиражирования раняемых исполнимых модулей 

при передаче третьим лицам от копирования 


ограничить доступ к файлам на 
компьютере пользователя 


Для системы 50РТКЕУ характерны: 

• надежный механизм криптографирования файлов и защиты программ от изучения логики их работы 

• уникальный алгоритм защиты для каждой распространяемой версии системы 

• минимальные требования к техническим и программным средствам 

• простота и удобство пользовательского интерфейса 

• поддержка любых форматов дискет и жестких дисков 

• отсутствие ограничений на количество защищаемых файлов и программ 


101000, Москва, Малая Лубянка, 16/4 


9309398, 9309552, 2567854 


Факс: 9210442 
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Десять лет назад был опубликован 
японский проект вычислительных 
систем пятого поколения, 
рассчитанный на реализацию в 
девяностые годы Несмотря на то, что 
проект не предполагал создания какого- 
либо коммерческого продукта даже к 
концу 90-х годов, а только проведение 
фундаментальных исследований, 
связанных с разработкой новой 
компьютерной технологии, замысел 
авторов показался достаточно 
амбициозным и фантастическим. 
Сегодня этот проект стал почти 
реальностью, а отдельные элементы 
проекта, касающиеся СБИС, 
компьютеров с параллельной 
архитектурой и программного 
обеспечения для них, уже реализованы. 


Основные языки 
программирования 
искусственного интеллекта 


НЕМНОГО ИСТОРИИ 

Что видишь ты еще 
В пучине темной лет минувших? 

УЛІекспіф. **Бзгря** 

Основной идеей японского проекта явился отказ от 
эволюционного подхода к разработке компьютерных 
систем будущего, состоящего в постепенном совершен- 
ствовании существующих технологий, и переход к 
принципиально новым архитектурам ЭВМ (КІ8С, 
СІЗС, компьютеры с параллельной архитектурой) и 
технологиям их изготовления (СБИС с количеством 
элементов более 1 миллиона), что позволило бы сде- 
лать следующий шаг в создании новых информацион- 
ных систем. Разработчики этого проекта считали, что 
системы обработки информации должны стать важ- 
нейшим структурообразующим фактором жизни обще- 
ства, охватывая экономику, искусство, науку, управле- 
ние, образование и культуру. ЭВМ пятого поколения 


должны обеспечить значительный рост качества про- 
дукции и производительности труда в промышленнос- 
ти. Японские специалисты считали, что решение этой 
проблемы по своему значению сравнимо с реализаци- 
ей продовольственной и энергетической программ. 
Предполагалось, что с помощью таких систем удастся 
решить проблемы оптимизации потребления энергии и 
вообще достичь эффективного использования всех ог- 
раниченных ресурсов, оставшихся в распоряжении че- 
ловечества. Совершенно особая роль отводилась маши- 
нам пятого поколения в охране окружающей среды, 
имеющей определяющее значение для прогресса во 
всех сферах. 

Японскими исследователями была предложена мо- 
дель ЭВМ пятого поколения, интегрирующая следую- 
щие технические и программные средства: 

Базовые программные средства 

- система решения задач и получения логических вы- 
водов 

- система управления базами знаний 


5 Зак. 2399 
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ОСНОВНЫЕ языки ПРОГРАММИРОВАНИЯ ИСКУССТВЕННОГО ИНТЕЛЛЕКТА 


- система интерфейсов 

Программные средства для системотехнических 
исследований 

- система программирования 

- система проектирования баз знаний 

- система проектирования СБИС 

Сервисная система 

- система утилит для работы с разнородными базами 
данных 

- средства автоматического контроля и восстановления 
информации 

- справочные средства 

Основные базы знаний 

- общая база знаний 

- системная база знаний 

- базы прикладных знаний 

Базовые прикладные системы 

- система машинного перевода 

- диалоговая система (запрос — ответ) 

- система распознавания речи 

- система распознавания образов и графических 
представлений 

> система решения прикладных задач 

Прикладные системы 

- система решения инженерных задач и задач 
проектирования 

- обучающие системы 

> автоматизированный офис 

- интеллектуальный робот 

Довольно неожиданно в этом длинном списке ин- 
теллектуальный робот оказался на самом последнем 
месте. Ведь, казалось бы, создание такого робота и 
должно являться целью разработки машин пятого по- 
коления, т.е. систем искусственного интеллекта (ИИ). 
Тем не менее, место для этого робота выбрано верное, 
поскольку путь по его созданию и тяжел, и долог. И 
если все-таки оглянуться назад, то мы увидим, что со 
времен первого известного упоминания об искусствен- 
ном интеллекте до самого последнего времени прог- 
ресс в этой области весьма невелик. Первое упомина- 
ние об искусственном разуме встречается у Тацита, 
который пишет, что, согласно легенде, для того, чтобы 
защитить Европу от тех, кто попытался бы вновь по- 
хитить ее и увезти домой в Финикию, Зевс создал 
бронзового робота, задачей которого было потопление 
всех кораблей, приближавшихся к Криту. Забавна и 
довольно свежая реальная история о маньяке-компью- 
тере, который работая в банке, регулярно рассылал 
клиентам уведомления, что за ними числится долг в 
00 долларов 00 центов, и не успокаивался до тех пор, 
пока не получал чек именно на эту сумму. Не будем 
критиковать создание Зевса, но вот во втором случае 
совершенно явно видна ошибка программиста. Старая 
истина верна: прежде, чем сделать Нечто, надо сде- 
лать инструменты, годные для создания этого Нечто. 
А в нашем случае речь идет о языках 
программирования искусственного интеллекта, о коих 
подробнее — ниже. 


ТРИ ИСТОЧНИКА 
и ТРИ СОСТАВНЫХ ЧАСТИ... 

По этому поводу я могу строить 
только расплывчатые и почти не 
имеющие никакого реального под- 
тверждения догадки. Сравнительная 
анатомия сделала пока лииіь первые 
шаги, а наблюдения натуралистов 
слишком неопределенны, чтобы пред- 
ставлять собой основу для серьезных 
выводов. 

Ж.>Ж. Руссо. ^^Рассуждения о происжождении 
и осиованин неравенства между людьми** 

Функциональный подход 
к задачам ИИ (Лисп) 

В результате почти полувековой практики програм- 
мирования был выработан весьма эффективный способ 
составления программ, при котором задача разбивает- 
ся на подзадачи, а те в свою очередь дробятся на эле- 
ментарные функции, определенное сочетание которых 
реализует решение подзадач и соответственно всей за- 
дачи. Процесс дробления на элементарные функции 
заканчивается тогда, когда каждая из полученных 
функций выполняет некоторую логически отдельную 
операцию и результат работы данной функции может 
служить входом для другой функции. Такое разбиение 
приводит к тому, что задача представляется некото- 
рым минимальным набором функций, который и коди- 
руется на языке, адекватном характеру задачи. 

Описанный функциональный подход оказался весь- 
ма эффективным для программирования на языке 
Лисп — языке обработки списков, ориентированном 
на символьную обработку данных. Трудно сказать, что 
функциональный подход является привилегией языка 
Лисп, этот подход дает прекрасные результаты и при 
использовании языков программирования Паскаль и 
Си. Первые попытки решить задачи ИИ на ЭВМ были 
предприняты в американских университетах в конце 
50-х годов, и в качестве рабочего был выбран единст- 
венно доступный язык символьной обработки — Ы8Р, 
основанный на алгебре списочных структур, лямбда- 
исчислении и теории рекурсивных функций. В связи с 
тем, что американские исследователи были законода- 
телями моды в работах по ИИ, за Лиспом утвердилась 
слава языка программирования для задач ИИ. Более 
чем за 25 лет своего существования язык Лисп был су- 
щественно расширен, появилось множество диалектов, 
но и по сей день язык Лисп не стандартизован. Наи- 
более известными диалектами являются ШТЕК_и5Р, 
гЕТА изр, РКАМг_и5Р и СОММОМ ЫЗР. послед- 
ний можно считать даже неким неофициальным стан- 
дартом. 

Основными типами данных языка Лисп являются 
атомы и списки. 

АТОМ — это цепочка из любых символов, не содер- 
жащая пробелов. 
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список — набор любого количества атомов и/или 
списков, разделенных пробелами и содержащихся 
внутри круглых скобок: (15 3 81) (А В (СО (Е) Р 
О). 

Для этих типов данных определены операции — 
функции, являющиеся примитивами языка: 

8ЕТ^ — присвоение (связывание) 

САК — возврат в качестве значения головной части 
списка 

СОК — возврат в качестве значения 'хвоста' списка 
СОЫ8 — включение нового элемента в начало списка 
ЕѴАЬ — вычисление значения выражения, находяще- 
гося внутри скобок 

ОЕР^N — определение функций пользователя. 

Прочие элементы языка Ы8Р являются результатом 
добавлений на уровне библиотечных нестандартизо- 
ванных функций со всеми вытекающими отсюда 
последствиями. 

Эти библиотечные функции позволяют создавать 
структуры данных пользователя, строить сложные вы- 
ражения по образцу, использовать макроопределения, 
варьировать способы задания аргументов функций и 
осуществлять потоковый ввод/вывод. 

Практически все реализации Лиспа требуют нали- 
чия мощного процессора и значительных ресурсов па- 
мяти. Профессиональная работа на Лиспе возможна в 
основном на сверхмощных Лисп-машинах типа 
ЗітЬоИсз 3600 и РАІМ-1 или хотя бы ѴАХ-1 1/780. 
Однако имеются реализации Лиспа и для персональ- 
ных компьютеров. 

Фирма Соіб Ніи іпс. (США) объявила о выпуске 
транслятора Соісіеп Соттоп Гізр ѵ 4.0 для работы в 
среде >Ѵіп(1о\ѵ8 3.0 фирмы МісгозоП. Версия 4.0 обес- 
печивает динамический обмен данными между 
^Vіп(^01V5 и приложениями, разработанными на СС 
Гізр. Новая версия позволяет осуществлять непосредс- 
твенный вызов функций, написанных на Си, из СС 
У зр- программы. Кроме того, пользователи получили 
возможность строить собственные динамически связы- 
ваемые библиотеки. Версия 4.0 выпущена для машин 
Сотрад 386, ІВМ Р8/2 моделей 70 и 80 и совмести- 
мых с ними. 

Фирма Ргапх Іпс. (США) объявила о выпуске 
АПе^го Соттоп Узр ѵ 4.0 и версии 2.0 АНе^го Сотро- 
зег — многооконной среды для разработки приложе- 
ний. Эта версия позволяет производить динамическую 
загрузку функций и использовать дополнительные на- 
боры символов. Эта версия предназначена для рабочих 
станций, работающих в среде ІІМІХ. 

Фирма Ьисісі Іпс. (США) выпустила Соттоп Узр 
ѵ.4.0, работающую в среде Х-\Ѵіп(1о^ѵз, и Соттоп Узр 
Іпіегіасе Мапа^ег (СУМ). Кроме того, фирма постав- 
ляет Тооі Кіі в виде программных средств для повы- 
шения эффективности программного кода. Эти прог- 
раммные продукты доступны для рабочих станций 
АроПо, 8ип, ОЕС, ІВМ, МСК и Ргіте. 

Фирма Зіетепз объявила о новой реализации Лиспа 
для малых машин типа В52000. Узр 8СЕ написан на 
ассемблере. Поставляемая фирмой среда для разработ- 


ки приложений включает: интерпретатор, компилятор, 
отладочные средства и системный интерфейс. 

Фирма Упе 8уз1ет Со Уб. (Япония) объявила о 
выпуске транслятора МоеЬіиз, который преобразует 
программы, написанные на Соттоп Узр'е, в 
программы на языке Си, которые должны работать в 
любой ІІМІХ-среде без Узр-интерпретатора. 

Логический подход к задачам ИИ (Пролог) 

Мечтой математиков-теоретиков, занятых проблема- 
ми ИИ, всегда была возможность применить логику в 
качестве языка программирования, предназначенного 
для использования эмпирических знаний и представ- 
ления закономерностей реального мира. Эти мечты 
породили в программировании целое Направление, на- 
зываемое логическим программированием, и лишь в 
малой степени реализовались в виде языка Пролог, 
изобретенного в 1973 г. группой исследователей Мар- 
сельского университета под руководством А. Колмерое. 

Логическое программирование должно базироваться 
на логике первого порядка с ее четко определенной се- 
мантикой и синтаксисом. Программист-логик должен 
записать аксиомы, описывающие задачу. При этом по- 
рядок следования аксиом не имеет значения, важна 
лишь их непротиворечивость. Такой идеал деклара- 
тивного программирования не удалось реализовать ни 
группе исследователей Эдинбургского университета, 
давших в 1979 г. одну из лучших реализаций Пролога 
на ЭВМ ОЕС- 10, ни другим исследователям. Язык 
Пролог основан на процедурной реализации логики 
первого порядка, вызове процедур по образцу и систе- 
мах описаний. Помимо отдельных устранимых недос- 
татков, Пролог обладает и такими недостатками, с ко- 
торыми очень трудно бороться, среди которых: 

- гипотеза о замкнутости мира, выражающаяся в виде 
предположения о полноте локально доступного зна- 
ния 

- ограничение логикой первого порядка 

- программист должен понимать и постоянно учиты- 
вать встроенный механизм возврата при поиске ре- 
шений. 

Гипотеза о полноте локально доступного знания 
приводит к тому, что некоторое утверждение, если оно 
не следует из локальной базы знаний, должно быть 
признано ложным, хотя это вовсе не так в открытой 
системе. Кроме того, любая система аксиом, выражаю- 
щая знания о мире, неизбежно оказывается противо- 
речивой. Согласно теореме Геделя, противоречивые 
системы аксиом бессмысленны, так как из противоре- 
чивого набора аксиом можно вывести любое абсурдное 
утверждение (при достаточном опыте). 

Ограничение логикой первого порядка 
(хорновскими выражениями) не позволяет адекватно 
описать некоторые задачи, возникающие в реальной 
жизни. Исследователи делают попытки перейти на 
логику второго порядка, однако реальных результатов 
пока нет, да и тогда это уже будет совсем другой 
язык. 
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ОСНОВНЫЕ языки ПРОГРАММИРОВАНИЯ ИСКУССТВЕННОГО ИНТЕЛЛЕКТА 


Очень большие надежды возлагаются на параллель- 
ные версии языка Пролог, так как они обеспечивают 
процесс вывода, не зависящий от порядка следования 
логических предложений и порядка указания целей 
внутри предложений, и — в силу этого — высокое 
быстродействие. 

Рассмотрим структуры данных и принципы логичес- 
кого программирования на примере наиболее популяр- 
ного среди советских программистов языке ТигЬо Рго- 
Іоб фирмы Вогіапб Іпіегпаііопаі (США). 

ОСНОВНЫЕ ТИПЫ ДАННЫХ ТигЬо РгоІО^: 
термы 

переменные (Х,Ѵ,2,С08Т) 

не-переменные 

объекты 

зутЬоІ 

зігіп^ 

іпіе^ег 

геаі 

сЬаг 

Піе 

списки [1,103,14,21] 
структуры NАМЕ(РNАМЕ,^NАМЕ) 

СТРУКТУРА ПРОГРАММЫ НА ТигЬо РгоІО^: 

(іотаіпз — определение типов данных, используемых 
в программе 

(ІаІаЬазе — предикаты динамической базы данных 
ргеёісаіез — все предикаты, используемые в програм- 
ме, за исключением динамических 
сіаизез — факты и правила для обработки данных 
(клозы). 

Программа на ТигЬо Ргоіо^ является как бы базой 
данных, которая неизменна во времени и фактически 
“заморожена" после того, как программа откомпили- 
рована. Некоторая часть базы данных является дина- 
мической и хранится вместе со статической. Динами- 
ческая часть базы данных может быть сохранена и 
восстановлена с помощью предикатов заѵе/сопзиіі. 

ВСТРОЕННЫЕ ПРЕДИКАТЫ 

ТигЬо Ргоіо^ содержит множество встроенных пре- 
дикатов, выполняющих разнообразные функции по уп- 
равлению, вводу — выводу данных, работе с экраном, 
преобразованию типов и т.д. 

При выполнении программы встроенный абстракт- 
ный интерпретатор ТигЬо Ргоіо^ пытается найти все 
возможные наборы значений, удовлетворяющие ука- 
занной в коде задачи цели. Если программист не 
включил в тело программы никакой цели, то ТигЬо 
Ргоіоя сам запросит ее указания при выполнении 
программы. 

Если пользователь указывает составную цель, то 
ТигЬо Ргоіо^ обрабатывает последовательно все подце- 
ли по порядку слева-направо. Алгоритм работы встро- 
енного абстрактного интерпретатора выглядит так: 

а) внутренний маркер устанавливается в начало базы 
данных; 


б) делается попытка удовлетворить самую левую цель 
в дереве подцелей 

в) осуществляется проверка, удовлетворяется выбран- 
ная подцель или нет; если удовлетворяется — пере- 
ход на “г)“; если не удовлетворяется, осуществляется 
проверка, имеются ли еще подцели в дереве; если 
таковые имеются, возобновляется просмотр базы дан- 
ных с текущего положения маркера; если в дереве 
подцелей больше ничего нет, то выдается сообщение, 
что цель не удовлетворена; 

г) маркер перемещается соответственно удовлетворен- 
ной цели; производится присвоение соответствующих 
переменных; 

д) осуществляется поиск подцелей справа в дереве 
подцелей; если таковые имеются, то следуует сооб- 
щение о найденном решении; если таких подцелей 
нет — переход на “е)“; 

е) устраняется подцель и осуществляется рекурсия с 
сокращенным списком подцелей. 

Естественно, что далеко не все задачи требуют та- 
кого стандартного алгоритма обработки дерева подце- 
лей. Для этого пользователю дается возможность уп- 
равлять обработкой подцелей с помощью предиката '!', 
не имеющего аргументов, который позволяет прервать 
стандартный алгоритм обработки подцелей при реали- 
зации указываемых программистом условий. 

Несмотря на отмеченные выше недостатки Пролога 
как языка логического программирования, он позволя- 
ет довольно быстро сделать работающий прототип сис- 
темы и поэкспериментировать с ним. При этом необ- 
ходимо тщательно проанализировать механизм обра- 
ботки целей и, если это требуется, отрегулировать его 
с помощью расстановки предиката '!'. Если пользова- 
теля не удовлетворяют временные характеристики ра- 
боты прототипа системы, можно переписать наиболее 
критичные куски программы на Си. 

В настоящее время имеется множество реализаций 
Пролога. Будет интересно проследить основные тен- 
денции в последних версиях программных средств, 
поступивших на рынок программного обеспечения. 

Фирма Риіпіиз Сотриіег Зузіетз іпс. (США) объя- 
вила о выпуске версии Риіпіиз Ргоіо^ 3.0, позволя- 
ющей включить программы, написанные на языке 
РК.ОШС, в приложения, написанные на языке Си. 
Эта версия (цена 10000 долларов) работает в среде 
Х-АѴіп(іо>ѵз и доступна для рабочих станций 8ип-3 и 
8ип-4. 

Фирма Еіза ЗоГЬѵаге (Франция) объявила о выпуске 
объектно-ориентированной системы, написанной на 
Прологе. Согласно утверждению фирмы, это полнос- 
тью декларативный объектно-ориентированный язык. 
От Пролога унаследована концепция не-детерминизма, 
принцип обработки дерева целей и сравнение с образ- 
цом, а от объектно-ориентированного программирова- 
ния взяты объекты и механизм наследования. Система 
работает в интерактивной многооконной среде Еар- 
Месііа. 

Фирма Ргоіо^іа (Франция) объявила о выпуске 
Рго1о^-Ш. Эта версия позволяет определять различные 
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ограничения для клозов в виде численных, булевских 
и других выражений. Эта версия предлагается для ре- 
шения сложных задач, таких как планирование произ- 
водства, инженерное проектирование и задач из облас- 
ти финансов. 

Фирма Ехрегі Зузіетз ^X6. (Англия) объявила о вы- 
пуске РгоІо^-2 для среды АѴіпбо^ 3.0 фирмы Місго- 
8оП. Этот программный продукт использует полную 
32-битную адресацию процессора і386 и систему вир- 
туальной памяти. Рго1ов-2 сосуществует со средой 
\Ѵіпсіо^ и отличается высокой производительностью 
на машинах, оснащенных процессором 80486 с такто- 
вой частотой 33 МГц. Цена лицензии 1495 ф.ст. 

Фирма Рагаіо^іс Іпс. (США) объявила о параллель- 
ной реализации эдинбургского Пролога для транспью- 
теров. Программное обеспечение, называемое п-рага1- 
1е1 Ргоіо^, автоматически распределяет Пролог-прог- 
рамму по п транспьютерам. При этом программа не 
должна модифицироваться для работы на различном 
количестве транспьютеров. В настоящее время выпу- 
щен интерпретатор, который работает с Іптоз-со- 
процессорами, а также доступна платформа, работаю- 
щая на сети ІВМ РС без транспьютеров. В качестве 
ядра системы предполагается использование 32-раз- 
рядного ВІ5С-процессора, работающего в параллели с 
другими транспьютерами. Стоимость поставки прог- 
раммного обеспечения для одного транспьютера сос- 
тавляет 250 долларов за интерпретатор и 10250 долла- 
ров за п-рага11е1 Ргоіо^ и платформу для пяти транс- 
пьютеров. 

Объектно-ориентированный подход 
к ИИ (С + + ) 

Читатели, проявляющие хотя бы некоторый интерес 
к зарубежной периодике, могут отметить стремление 
разработчиков программного обеспечения работать в 
объектно-ориентированной среде. Даже разработчики 
программ на Лиспе и Прологе стараются дописать 
стандартное матобеспечение, чтобы иметь возмож- 
ность работать в объектно-ориентированной идеоло- 
гии. И это не просто мода, а естественное стремление 
сократить время разработки, облегчить повторное ис- 
пользование отлаженных модулей и снизить издержки 
на сопровождение работающего мато(5еспечения. Объ- 
ектно-ориентированое программирование (ООП) — 
это новая философия программирования, новый спо- 
соб мышления для программистов, самым существен- 
ным моментом которого является объединение струк- 
тур данных с операциями, которые можно осуществ- 
лять с этими структурами данных. Эта новая идеоло- 
гия является развитием старого хорошо известного 
структурного подхода, она в (большей степени соответ- 
ствует мышлению нормального человека (непрограм- 
миста). После того как произведен структурный ана- 
лиз проблемы и выделены необходимые для описания 
проблемы структуры данных, аналитик уже должен 
для себя представлять, какие операции он может осу- 
ществлять с выбранными структурами данных. 


Мышление человека имеет скорее ассоциативный 
характер, и при рассмотрении новых проблем мы пы- 
таемся связать возникающие новые концепции с уже 
известными и установить между ними дедуктивные 
связи. Весьма продуктивными оказываются попытки 
классифицировать проблему и представить ее в виде 
дерева, на нижних уровнях которого находятся уже 
известные структуры, а верхние уровни являются обо- 
бщением концепций и структур нижних (исходных) 
уровней. Именно так человек постигает окружающий 
его мир с древних времен (уже китайская и древнегре- 
ческая философия ввели исходные элементы для о^- 
яснения мира). Поэтому нет ничего удивительного в 
том, что именно исследователи в области ИИ первыми 
взяли на вооружение ООП. Программирование имеет 
полувековую традицию, основанную на идеях, зало- 
женных фон Нейманом, и выработало свою идеоло- 
гию, выраженную в таких языках программирования, 
как Ассемблер, Фортран, Паскаль, Ада. Си. Все эти 
языки по своей структуре **привязаны** в большей или 
меньшей степени непосредственно к устройству маши- 
ны. Новый язык программирования С-н- в первую оче- 
редь “привязан** к процессу мышления человека и 
лишь на нижних уровнях — к устройству ЭВМ. ООП 
позволяет по- новому взглянуть на процесс програм- 
мирования вообще и на составление программ в част- 
ности. Естественно, язык программирования не 
родился вдруг на пустом месте, ему предшествовали 
языки 8ІМІЛА и 8МА1ХТА1Х, которые в качестве 
данных использовали “объекты**. Именно с этими 
языками впервые было связано понятие ООП. Они не 
получили широкого распространения, и лишь в 1985 
году с выпуском спецификаций объектно- 
ориентированного языка С-н- корпорацией АТйгТ (Веіі 
ЕаЬогаІогіез) стало ясно, что в программировании 
грядет революция. Будем надеяться, что эта 
революция не принесет трагических последствий для 
человечества, так как никто пока не собирается 
отказываться от сделанного в программировании за 50 
лет. 

Центральным понятием в языке является поня- 
тие класса (сіазз), являющееся обобщением понятия 
структуры в стандартном языке Си. 

ОБЪЕКТ имеет уникальный набор переменных, кото- 
рый соответствует по имени и типу элементам дан- 
ных, определенных для его класса. 

УКАЗАТЕЛЬ (роіпіег) на объект обеспечивает косвен- 
ный способ доступа к объектам. Определив набор 
классов и операций, мы можем понять, что конкрет- 
но делает данная программа. Именно в определении 
класса мы используем основной принцип ООП — 
инкапсуляцию. 

ИНКАПСУЛЯЦИЯ — объединение в одном элементе 
и данных, и процедуры их обработки. Именно ин- 
капсуляция делает С-н- таким привлекательным язы- 
ком для программирования задач ИИ, так как мы 
можем определить данные, входящие в классы, и 
действия, которые могут выполняться над этими дан- 
ными, как некоторую структуру-объект в системе. 
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работающей согласно набору правил (продукционной 
системе), или определить объекты, соответствующие 
фреймам, и обращаться к ним в программе как к 
объекту. 

Вторым основополагающим принципом ООП явля- 
ется принцип наследования. 

НАСЛЕДОВАНИЕ — это сохранение, перенос атрибу- 
тов данных и выполняемых над ними операций от 
объекта к объекту. С помощью этого принципа стро- 
ятся различные иерархии классов, (простое наследо- 
вание), а также смешанные классы (множественное 
наследование), когда некоторый новый класс однов- 
ременно наследует атрибуты и выполняемые над ним 
операции от нескольких базовых классов. При этом 
имеется возможность модифицировать “поведение** 
объектов. Аналогия с генетикой в данном случае 
весьма яркая. 

ПОЛИМОРФИЗМ означает возможность единообраз- 
ного обращения к объектам в тексте программы при 
сохранении уникальности поведения объектов. Этот 
принцип позволяет определять целый ряд объектов 
на основе одного базового класса и обращаться к ним 
единообразно при сохранении специфического пове- 
дения каждого из объектов. Так операция сравнения 
различных объектов возможна только тогда, когда 
базовый класс определяет метод сравнения. 


Реляционная СУБД 
ОаіаЕаве 


- лицензионная чистота 
приложений; 

- продукт, адаптированный для 
СССР фирмой-изготовителем; 

- очень высокая скорость 
разработки приложений; 

- цены ниже рыночных; 

- значительная скидка учебным 
заведениям. 

Более 500 наиболее преуспевающих 
компаний мира остановили свой 
выбор на СУБД ОаіаЕазе. 

ДАВАЙТЕ ВЫБИРАТЬ 
ВМЕСТЕ С НАМИ!!! 


Наш адрес: 252124, Киев, 

ул. Ватченко 15, 
МВП ”КИТ” 

Телефоны: (044) 441-18-43 

(044) 274-88-35 
(с 14:00) 

Факс: (044) 228-72-72 


Именно эти три основных принципа ООП: инкапсу- 
ляция — наследование — полиморфизм делают ООП на 
языке С-н- таким многообещающим. Возможно, неко- 
торые пользователи испытывают неприятные впечат- 
ления от нового синтаксиса С-н-, отличающегося от 
привычного синтаксиса стандартного языка Си, и сов- 
сем другой философии программирования. Как только 
вы освоитесь с новой идеологией, все остальные проб- 
лемы покажутся вам не такими уж серьезными. 

Фирма Хогіес Іпс.(США) объявила о создании паке- 
та Сн- Оеѵеіорег Есііиоп ѵ. 2.1 для М5-005, Ѵ^іпс1о\ѵ5 
3.0, 08 /2, 00 8 386, ОМІХ 386. В 008 386 имеется 
возможность адресации до 4 Гигабайтов памяти. Кро- 
ме того, фирма объявила о выпуске библиотеки клас- 
сов Сн ОаіаЬазе для создания объектно-ориентиро- 
ванных баз данных. Эти программные продукты име- 
ют возможность работы с Ѵігіиаі Собе Мапа^ег 
(ѴСМ) — системой управления виртуальной памятью, 
которая позволяет использовать до 4 Мегабайтов памя- 
ти в программе пользователя. Транслятор Сн может 
генерировать код для всех указанных операционных 
систем. 

Фирма Вогіапсі Іпіегпаііопаі выпустила два объект- 
но-ориентированных программных продукта: ТигЬо 
Разсаі ѵ.6.0 и ТигЬо Сн- ѵ.1.0. ТигЬо Сн соответству- 
ет стандарту корпорации АТ&Т ѵ.2.0. Оба програм- 
мных продукта имеют дружественную к пользователю 
интерактивную многооконную среду для разработки 
программ (ШЕ) и встроенную систему управления 
виртуальной памятью, управление которой доступно 
пользователю из программ (ѴКООММ). Кроме того, 
фирма поставляет ТигЬо Сн- РгоГеззіопаІ для профес- 
сиональных разработчиков. Поставка включает транс- 
лятор Сн, реализующий два стандарта АМ8І С и 
стандарт АТ&ТСн. В эту поставку входит также 
символьный отладчик ТигЬо ОеЬи^^ег, ТигЬо АззетЬ- 
Іег, полностью совместимый с ассемблером МА8М 
фирмы МісгозоП и РгоРіІе, позволяющий оптимизиро- 
вать программный код. 

А, Пантелеймонов 
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ОСНОВНЫЕ ПОНЯТИЯ, 

ИСПОЛЬЗУЕМЫЕ ПРИ ПРОГРАММИРОВАНИИ ИСКУССТВЕННОГО 

ИНТЕЛЛЕКТА 


ОБЪЕКТЫ — элементы, посредст- 
вом которых описывается ис- 
следуемая система (универ- 
сум). 

Объекты бывают: 

- элементарные 

- составные 

- объекты-переменные. 
ОТНОШЕНИЯ — множество логи- 
чески связанных объектов. 

МИР — набор знаний, который мо- 
жет использоваться при ре- 
шении той или иной задачи. 
Одновременно в универсуме 
могут сосуществовать нес- 
колько миров. Мир может 
создаваться динамически из 
некоторого множества объек- 
тов. 

КЛАСС — это множество объектов с 
идентичными свойствами. 
Свойства объектов класса за- 
даются структурой данных 
объектов (схемой экземпля- 
ров класса) и определенными 
на них отношениями. 

ФАКТ — это констатация того, что 
между объектами выполняет- 
ся определенное отношение. 
Факт является простейшим 
видом утверждения. 


ЦЕЛЬ — объект, являющийся пред- 
метом поиска в базе данных. 

ЛОГИЧЕСКИЕ ПЕРЕМЕННЫЕ слу- 
жат для обозначения неопре- 
деленных объектов. В логи- 
ческих программах перемен- 
ная обозначает неопределен- 
ный, но единственный объ- 
ект, а не некоторую область 
памяти, как в программах на 
языках Бейсик, Фортран, 
Паскаль, Си и Лисп. Логи- 
ческие переменные обознача- 
ются заглавными буквами. 

ТЕРМ — это базовая структура дан- 
ных в логических программах 
(константы и переменные). 

ФУНКТОР — запись операции, вы- 
полняемой над термами. 
Функтор задается именем и 
своей арностью (числом аргу- 
ментов) . 

СОСТАВНОЙ ТЕРМ — структура 
данных, содержащая функтор 
и последовательность из од- 
ного или более аргументов, 
являющихся термами. 

ВЫЧИ(ІЛЕНИЕ логической програм- 
мы Р состоит в построении 
примера, логически выводи- 
мого из программы Р. Цель 


С выводима из Р, если су- 
ществует такой пример А 
цели С, что А <-В1, В2, ..., 
Вп, п>0 — пример 
предложения в Р, где каждое 
В выводимо из Р. 

ПРАВИЛА — это утверждения вида 
А< — В1, В2, ..., Вп, где 

п>0. При этом А называется 
заголовком правила, а В1, 
В2, ..., Вп — телом правила. 

ПРОЦЕДУРА — совокупность пра- 
вил с одним и тем же утвер- 
ждением в заголовке. 

ЛОГИЧЕСКАЯ ПРОГРАММА — это 
конечное множество правил 
(предложений). 

ВОПРОС — конъюнкция вида А1, 
А2, ..., Ап?, где п>0 и 

А1,...,Ап — это цели. Счита- 
ется, что переменные в воп- 
росе связаны квантором су- 
ществования. 

РЕЗОЛЬВЕНТА — текущая цель на 
некоторой стадии вычисления 
логической программы. 

ДЕРЕВО ВЫВОДА состоит из вер- 
шин и ребер и изображает 
цели, снимаемые в процессе 
вычисления логической прог- 
раммы. 


В августовском номере журнала ТЬе РиПігізі, органе 
всемирного общества футурологов, представитель фирмы 
ІпІегІеаГ Дэйв Уайнбергер пишет, что будущие документы 
будут не только предоставлять информацию, но и подстра- 
ивать свое содержимое под конкретного читателя. 

По Уайнбергеру, компьютерные документы скоро будут 
сами добавлять информацию, изменять графику и даже 
определять, что читатель может, а что не может увидеть. 
Это будут своеобразные “активные публикации“, меняю- 
щиеся в зависимости от того, кто их читает. 

Эта идея возникла не сегодня. На осенней выставке 
Сошсіех, демонстрируя подобную систему, Уайнбергер зая- 
вил, что система “умных документов“ требует для своей 
работы быстрого компьютера на 80386 процессоре или Ма- 
кинтоша. 

N€^^3 Ыеіуюгк, 23 /иіу, 1991 

Исследование, проведенное профессором Джеймсом 
Шиди из Калифорнии показало, что работоспособность че- 
ловека, использующего 19-дюймовый черно-белый мони- 
тор с тактовой частотой 67 Гц и отображением черных 


букв на белом фоне на треть выше работающего на стан- 
дартном ѴСА-мониторе. 

Исследование было проведено по заказу фирмы 
Сотегзіопе ТесНпоІо^, которая и производит эти хорошие 
мониторы (2495 долларов -больше, чем цена многих ком- 
пьютеров) . 

Проверялась способность человека в течение длительно- 
го времени читать один и тот же текст на экране. При 
этом не было получено никаких свидетельств того, что 
частая смена документов или перевод взгляда с экрана на 
бумагу, как это бывает при вводе информации, может 
улучшить производительность труда. 

Общая тенденция состоит в том, что белый фон на эк- 
ране лучше, чем черный, высокая частота развертки мони- 
тора лучше, чем низкая, и легче читать тексты с более вы- 
соким разрешением. 

Еще одно исследование, произведенное калифорнийс- 
ким медиком, продемонстрировало существенно более вы- 
сокую продуктивность при чтении текста на бумаге по 
сравнению с компьютерным экраном. 

Nеу^зЬуіез Ые\^^з ЫеЬюгк, 23 /иіу» 1991 
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ОТ С к С + + . ЗАПИСКИ ХАКЕРА 



^\редлагаемый материал предназначен 
для программистов, знакомых с языком 
С. Статья последовательно вводит в 
язык С++. Синтаксис языка и его 
основные идеи представлены 
достаточно полно, что позволяет 
совершить легкий переход к новому 
языку. Тем не менее статью нельзя 
рассматривать как описание языка 
С+ + — это скорее попытка поделиться 
двухлетним опытом работы с 
системами ТигЬо С и ТигЪо С+ +. 


От С К С++. 
Записки хакера 


Развитие технологии 
и языков программирования 

Существующее разнообразие языков программиро- 
вания легко поставит в затруднение человека неиску- 
шенного. Когда начинающий программист приступает 
к работе над новым программным проектом, ему бы- 
вает сложно выбрать подходящий язык в том море ин- 
струментальных пакетов, где ВА5ІС и РОКТІШ4 сосед- 
ствуют с С-И-, объектными МООІЛЛ и РАЗСАЬ. Этот 
выбор станет проще, если понять развитие идей про- 
граммирования и их реализацию в языках программи- 
рования. Отсутствие ясного понимания задач и целей, 
которые преследовались при создании того или иного 
языка, вызывает споры и попытки сравнения часто не- 
сравнимых языков. Видимо, отсюда появляются жур- 
нальные статьи-монстры типа “Структурное програм- 
мирование на ВА$ІС“. Только поняв идеи, заложенные 
авторами в тот или иной язык, можно использовать 
его в полную силу. Ниже мы попытаемся проследить 
развитие концепций программирования и проанализи- 
ровать, как они влияли на вновь создаваемые языки. 

Историю языков программирования высокого уровня 
традиционно ведут с появления языка РОКТІШ4. Дей- 
ствительно, РОКТІШ^ стал первым языком, для кото- 


рого был реализован транслятор. Современные по- 
клонники этого языка вряд ли узнали бы синтаксис 
первых версий РОКТКАN. Достаточно сказать, что он 
не предусматривал такого понятия, как подпрограмма, 
ведь язык был предназначен исключительно для тран- 
сляции формул (РОКти1а-ТКАN81аЩ^). Однако этот 
древнейший предок современных языков уже содержал 
в себе концепцию ЯЗЫКА ВЫСОКОГО УРОВНЯ, позво- 
лившую программисту отвлечься от жесткой привя- 
занности к машине, памяти, адресам и заняться со- 
зданием алгоритма, а не чисто механическим перево- 
дом своих идей в машинные коды. 

Совершенствование синтаксиса языка часто выпа- 
дает из поля зрения, когда речь заходит о развитии 
концепций программирования. Да и самих этих кон- 
цепций иной специалист назовет не больше одной- 
двух. Между тем РОКТІШ^ вобрал в себя многие идеи, 
вся красота и мощь которых стала ясна значительно 
позже. Одна из них — идея подпрограммы. Как уже 
было сказано, древнейший ГОК'ШАN не знал понятия 
подпрограммы; она появилась в нем позже, предвосхи- 
тив идею МОДУЛЬНОГО ПРОГРАММИРОВАНИЯ. 

Следующим этапом в развитии технологии про- 
граммирования стала концепция СТРУКТУРНОГО ПРО- 
ГРАММИРОВАНИЯ. Часто при попытке описать суть 
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этой концепции говорят лишь о том, что она за- 
прещает использование оператора безусловного пере- 
хода СОТО. Но это не совсем так. Данный подход со- 
держит в себе несколько идей, позволяющих представ- 
лять алгоритмы в виде блочной структуры, а не при 
помощи нагромождения операторов СОТО. Эти идеи 
определили и синтаксис нового языка программирова- 
ния — АЬСОЬ. Назовем отличительные черты этого 
языка: 

- операторные скобки, синтаксически объединяющие 
группу операторов в один оператор-блок; 

- условный оператор с альтернативой (IР-ТНЕN-Е^8Е); 

- несколько разновидностей операторов цикла 
(индексный, с предусловием, с постусловием, по пе- 
речислению, безусловный с выходом непосредственно 
из тела цикла). 

Все эти нововведения позволили отказаться от при- 
менения оператора СОТО — он просто стал не нужен. 
Кроме этого, появилось требование ОБЯЗАТЕЛЬНОГО 
ОПИСАНИЯ ДАННЫХ. Так, была предпринята попытка 
систематизировать труд программиста; сделать его пе- 
дантом, аккуратно описывающим данные и алгоритм. 

Если удалось структурировать алгоритм, то почему 
бы не структурировать и данные? Эта идея была за- 
ложена в концепцию АБСТРАКЦИИ ДАННЫХ. Смысл 
ее состоял в том, чтобы позволить программисту опи- 
сывать новые типы данных со сколь угодно сложной 
структурой и работать с ними как с единым целым. 
Такой подход был немедленно использован в языке 
РА8САЕ. Программисты АЬСОЬ хорошо представляют 
себе все ухищрения, к которым надо было прибегнуть 
при попытке работать со временем, представленным в 
виде часов, минут и секунд. На РАЗСАЬ же достаточно 
описать новый тип переменных Ііте, представляющий 
собой запись (структуру), содержащую три поля: Ноиг, 
тіп, зес. Программисты, сразу начавшие на РА5САЕ 
или другом подобном языке, просто не замечают всего 
значения такого подхода. Конечно, приведенный при- 
мер прост; его легко реализовать и не имея специаль- 
ных средств. Но представьте себе, что вам надо рабо- 
тать с объектами более сложной структуры, содержа- 
щими десятки полей данных. Как быть тогда? Здесь 
на помощь приходят языки типа РАЗСАЬ. 

С течением времени программные проекты стано- 
вились сложнее и больше по размеру. Развитие техно- 
логии программирования требовало подхода, который 
позволил бы выделять алгоритмы, данные и описания 
новых типов в независимые блоки — МОДУЛИ. Мо- 
дульный подход заключается отнюдь не в разбиении 
программы на части. В языках, ориентированных на 
модульный подход, предусмотрены специальные сред- 
ства, позволяющие создавать независимые пакеты 
(под) программ, устанавливать жесткий контроль ти- 
пов, определять видимость переменных и процедур. 
В таких модулях различают РАЗДЕЛ ОПИСАНИЙ и 
РАЗДЕЛ РЕАЛИЗАЦИЙ. Раздел реализаций содержит 
информацию, необходимую для помещения данного 
модуля в библиотеку (алгоритмы и данные). Раздел 
описаний содержит информацию, необходимую тран- 


слятору для правильной связи (интерфейса) с данным 
модулем (описания типов, данных, типов процедур и 
их формальных параметров). При **сборке** головной 
программы раздел реализаций не транслируется — 
транслятор всю необходимую информацию получает 
из раздела описаний, а процедуры берутся уже гото- 
выми из библиотеки. Всеми этими чертами обладает 
МООША-2, С и некоторые реализации РАЗСАЬ 
(ТигЬо 4.0 и выше). 

Новомодной концепцией стало ОБЪЕКТНО-ОРИЕН- 
ТИРОВАННОЕ ПРОГРАММИРОВАНИЕ. Данный подход 
заключается в объединении данных и алгоритмов, 
относящихся к одному типу объектов, в единое описа- 
ние КЛАССА ОБЪЕКТОВ (ИНКАПСУЛЯЦИЯ). При этом 
алгоритмы называются МЕТОДАМИ данного класса. 
Кроме того, в объектно-ориентированных языках 
предусмотрен механизм ПОРОЖДЕНИЯ КЛАССОВ — 
когда порождаемый класс НАСЛЕДУЕТ данные и ме- 
тоды порождающего класса. При этом имеет место 
ПОЛИМОРФИЗМ методов — метод с одним именем 
может исполняться по-разному для порождаемого и 
порождающего классов (допускаются различные ре- 
ализации). Разумеется, вы можете добавить в порож- 
даемый класс новые данные и методы. Как правило, 
предусматривается способ описания доступности полей 
данных и методов. Объектно-ориентированными язы- 
ками являются С-и- и некоторые реализации РАЗСАЕ 
(ТигЬо 5.5 и выше). 

Объектно-ориентированный подход предоставляет 
не только удобный синтаксис языка. Стержнем его 
следует считать механизм порождения классов. Воз- 
можность создания разветвленной иерархии классов 
позволяет сблизить программиста-профессионала и 
специалиста, занимающегося программированием для 
решения своих прикладных задач. Первый занимается 
конструированием иерархии классов, описывая их ме- 
тоды и поля данных, а второй — написанием про- 
граммы в терминах, близких его специализации 
(используя описания классов). 

Прочитав все это, кто-то скажет: “Да я вам любую 
программу напишу на РОКТТШ^'е!**. Добавим, что и в 
машинных кодах можно написать любую программу 
(теоретически), но так ведь никто не поступает. Все 
дело во времени и усилиях, затраченных на создание 
и отладку программы. Любой язык программирования 
вбирает в себя современные ему идеи, систематизиру- 
ющие и облегчающие труд программисі'а. Это один из 
главных аргументов при выборе подход^іщего языка! 

Модульность 

1. Техника перевода. 

Транслятор, редактор связей 

ТигЬо С-Н-, как и прочие его Тигію-предшествен- 
ники, придерживается традиционной т«ехнологии пере- 
вода программ в исполняемые коды. Эта технология, 
наработанная поколениями программистов, применя- 
ется в подавляющем большинстве транс хпяторов. 
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Процесс перевода программы в исполняемый файл 
делится на два этапа: трансляция и сборка 

(компоновка или редактирование связей). Трансляция 
заключается в переводе программы, написанной на 
языке программирования, в исполняемый код. Однако 
при этом транслятор не в состоянии указать конкрет- 
ных адресов внешних имен; он просто заменяет их со- 
ответствующими ссылками. Что это значит? Предпо- 
ложим, у вас есть функция (ипсК), и вы вызываете из 
нее функцию ^ипс2(). Транслятор понятия не имеет о 
том, где находится Гипс2(), поэтому при вызове он не 
в состоянии указать конкретный адрес этой функции 
(да это и не входит в его задачи). Транслятор просто 
составляет из имен функций таблицу внешних имен 
или ссылок. В эту же таблицу попадают и внешние 
переменные (не путать с глобальными). Таблица вне- 
шних имен и ссылок в совокупности с исполняемым 
кодом и составляют файл с расширением *.оЬ], или 
объектный файл. Строго говоря, создаются две таб- 
лицы: одна содержит список имен и адресов объектов 
(функций и переменных), которые присутствуют в 
данном файле, другая — список имен, на которые 
были сделаны ссылки и адреса которых надо конкре- 
тизировать. 

Теперь наступает очередь редактора связей 
(компоновщика). В его задачи входит сборка объект- 
ных файлов (их, как правило, несколько) и разреше- 
ние внешних ссылок (подстановка конкретных адре- 
сов), указанных в соответствующих таблицах. Упро- 
щенно это выглядит так: все исполняемые коды запи- 
сываются подряд, после чего расставляются уже кон- 
кретные адреса функций и внешних переменных. 
Однако на этом работа обычно не заканчивается. Ред- 
кая программа обходится без обращения к библиоте- 
кам (так, например, функция ргіпіИ) помещается в 
одной из системных библиотек). Поэтому остается 
еще масса неудовлетворенных внешних ссылок, 
которые компоновщик пытается удовлетворить, 
отыскивая соответствующую функцию в библиотеке. 
Если функция найдена, то ее исполняемый код 
добавляется в конец программы; если нет — то 
внешняя ссылка остается неудовлетворенной (или 
неразрешенной). Если удовлетворены все внешние 
ссылки, то создается исполняемый файл. Если нет — 
выдается соо<5щение об ошибках. 

Библиотеки отличаются от объектных файлов лишь 
тем, что содержимое объектных файлов полностью 
попадает в исполняемый файл, а из библиотек выби- 
раются только необходимые фрагменты. Поэтому на- 
иболее часто используемые функции следует объеди- 
нять в библи(угеки. 

2. Оформ ление модулей 

Предположим, что вы объединили часть своих фун- 
кций в модуль и хотите воспользоваться преимуще- 
ствами концепции модульного программирования. Для 
этого вам придется разбить свой модуль на две ча- 
сти — раздел описаний и раздел реализаций. Раздел 


описаний содержит в себе все описания типов, пере- 
менных и функций. Раздел реализаций содержит тек- 
сты самих функций. (Более подробно см. в разделе 
“Развитие технологии и языков программирования**.) 

В языке С традиционно оба раздела помещаются в 
разные файлы. Раздел реализаций помещается в файл 
с расширением *.С, а раздел описаний — в файл с 
расширением *.Н (Н-файл, или Неабег-файл). 
(Сделаем оговорку, что все приведенные ниже при- 
меры программ будут правильно работать в системе 
ТигЬо С-Н-, однако с другими трансляторами могут 
возникнуть некоторые проблемы.) 

Допустим, ваш модуль называется МОП1 и содержит 
функции ?ипс1(), ?ипс2(), ГипсЗО. В этом случае со- 
держимое файлов может быть следующим: 

/♦ Файл МОП1.Н V 


#іГпбеГ МОП1 Н 
#беПпе“”М001““Н 


іЩ Гипсі (ііКх); 
боиЫе (ипс2 (іп! х, іп( у) ; 
боиЫе ГипсЗ (боиЫе г); 

#епбі^ 

/♦ конец V 


Операторы препроцессора заставляют транслятор 
обходить данный файл в том случае, если он уже 
транслировался. 

/♦ Файл МОП1.С V 


#іпс1ибе “МОПІ.Н** 

іпі Гипсі (ІПІ х) { 

/* 

Текст функции ГипсИ) 

^оиЫе Гипс2 (іп( х,ііі( у){ 

Г 

Текст функции Гипс2() 

боиЫе ГипсЗ (боиЫе г){ 

Г 

Текст функции ГипсЗ О 

/♦ конец •/ 


Если теперь вы захотите использовать функции из 
модуля М001, то вам достаточно будет сделать дос- 
тупным транслятору файл М001.Н при помощи опе- 
ратора #іпс1ибе, а задачу сборки решит компо- 
новщик. 

Теперь предположим, что вы написали несколько 
модулей (один из которых содержит функцию таіпО) 
и хотите собрать их в единую программу. Здесь у вас 
есть выбор. Возможность номер один: воспользуйтесь 
файлом проекта. В этом файле вы перечисляете мо- 
дули, входящие в проект (возможно, написанные на 
разных языках программирования). Интегрированная 
среда ТигЬо С будет автоматически транслировать мо- 
дули проекта в объектные файлы и передавать их 
компоновщику. Возможность номер два: поместите 
ваш модуль в библиотеку. В этом случае надо описать 
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вашу библиотеку в файле проекта. Первый вариант 
предпочтительнее на этапе отладки модуля, второй — 
если модуль уже отлажен. 

Есть и третий путь — включить файл реализаций в 
головной файл, используя оператор #іпс1ис1е. 

Простые расширения языка С 

1. Новое в описании типов и переменных 

Надо сказать, что создатели языка С++ постарались 
учесть критику сторонников жестко типизированных 
языков. Язык стал более требовательным к соответ- 
ствию типов параметров функций и возвращаемых 
значений. Теперь любая функций, используемая в 
программе, должна быть описана до первого к ней 
обращения. Жесткое ограничение наложено и на типы 
указателей. Даже для переменной типа ѵоіб необхо- 
димо задавать явное преобразование типа. Например, 
размещение динамического массива типа боиЫе дол- 
жно выглядеть так: 

(ІоиЫе *а; 

а = (доиЫе ♦) таііос (N * хігеоНсІоиЫе)) ; 

Упрощено введение новых типов. В языке С для 
ввода нового типа нужно было использовать слово 
іуресІеГ Теперь любое описание структуры или совме- 
щения (ипіоп) — его еще называют объединением — 
вводит новый тип. Если вы описали структуру или со- 
вмещение. то вы с полным основанием можете 
использовать это имя при описании новых перемен- 
ных. опуская слово зігисі или ипіоп. 

Переменная может быть описана в любом месте 
блока, заключенного в фигурные скобки. Раньше пе- 
ременная описывалась до первого исполнимого опера- 
тора в блоке, теперь это ограничение снято. Главное, 
чтобы переменная была описана до ее использования. 

В язык введено понятие константы. Если раньше 
надо было писать: 

#(1еПпе РІ 3.1415 

то теперь допускается следующая запись: 

СОП8ІРІ = 3.1415 

При этом транслятор сам определит тип константы 
и будет следить за тем. чтобы ее значение не меня- 
лось. 

После введения этих соглашений язык С++ стал бо- 
лее строгим, но также и более стройным в отношении 
работы с типами. 

2. Комментирование конца строки 

В С-н- добавлен новый способ записи комментариев. 
Вы можете закомментировать конец строки, отделив 
его двумя символами '/'. Конец строки вместе с этими 
символами не будет воспринят транслятором. 


3. Функции іпИпе 

Любой программист на С наверняка сталкивался с 
побочными эффектами при применении макроязыка. 
Новичок приходит в восторг, обнаружив, что при 
использовании макроподстановки ізсИ^и (^еіс (Піе)) 
вводится два символа. Такое проявление побочных 
эффектов связано с многократным использованием ар- 
гументов в макроопределении #(1еНпе. Основной си- 
лой этого оператора считалось то. что он создает как 
бы функцию, код которой вставляется непосред- 
ственно в место вызова. Однако наличие побочных 
эффектов значительно ограничивало его применение. 

Все проблемы разрешила функция с описателем іп- 
Ііпе. Эта идея была применена в языке АОА и позднее 
использована создателями С++. При обращении к 
функции с описателем іпііпе не происходит реального 
вызова, а исполняется код функции, который трансля- 
тор вставляет непосредственно в место обращения. Это 
позволяет экономить время на вызове функции. Есте- 
ственно, что функция должна быть достаточно корот- 
кой. 

Вот пример такой функции: 
іпііпе доиЫе 8цг (сІоиЫе х) {геШгп х*х;} 

Надо сказать, что реализация этой функции должна 
быть “под рукой“ у транслятора — иначе он не смо- 
жет вставить ее код в нужное место. Поэтому описа- 
ние таких функции надо помещать не в раздел реали- 
заций, а в раздел описаний (в Неадег-файл — файл с 
расширением *.Н). 

Функции, содержащие циклы или ассемблерные 
вставки, не могут быть іпііпе-функциями. Транслятор 
проигнорирует этот описатель, выдав соответствующее 
сообщение. 

4. Функции оѵегіоасі (перезагружаемые) 

Важным расширением, также пришедшим из языка 
АВА, является то, что транслятор С++ различает фун- 
кции не только по именам, но и по типу аргументов. 
Например, функцию 
СІоиЫе 8дг (доиЫе х) {геПіт х*х;} 

можно дополнить функцией 
іШ 8ЯГ (ІПІ х) {геіит х*х;} 

Обе спокойно уживаются в одной программе. При вы- 
зове будет использована одна из функций. Какая — 
решает тип аргумента. 

Раскроем секрет транслятора ТигЬо С++. Истори- 
ческое название оѵегіоасі никакого отношения к дей- 
ствительности не имеет. Просто транслятор в своей 
работе использует внутренние имена функций, суще- 
ственно отличающиеся от используемых в программе. 
Эти имена содержат в себе скрытое описание типов 
аргументов. Разные типы аргументов — разные имена. 
С этими же именами работают программы компонов- 
щика и библиотекаря. Данный механизм и позволяет 
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нам иметь несколько разных функций с одинаковыми 
именами, но с разными типами аргументов. 

Заметим, что транслятор не различает функции по 
типу возвращаемого значения. 

5. Параметры функции 
по умолчанию 

Допустим, вы имеете функцию для вывода матрицы 
в файл. Как правило, такие функции снабжаются сер- 
висным набором “бантиков" и “финтифлюшек", кото- 
рые используются редко или единообразно. Например, 
наша функция позволяет задать формат вывода чисел 
и заголовок вывода. При этом нежелательно застав- 
лять программиста указывать все необходимые пара- 
метры при вызове функции. Не вдаваясь в описание 
типа МАТКІХ и реализацию самой функции, приведем 
ее описание: 

ргіпі (МАТКІХ А, сЬаг ♦ГогшаІ = “%9.4 “, сНаг ♦Шіе = 

После этого законны следующие обращения к фун- 
кции: 

МАТКІХ С; 

ргіп! (С); 

ргііН (С, “ %12.7е “); 

ргіп! (С, “ %12.7е “, Матрица С 

Если для некоторых аргументов функции можно 
указать наиболее часто используемые значения, то 
С++ позволяет это сделать, избавляя программиста от 
необходимости указывать их каждый раз при обраще- 
нии. При описании функции вы можете задать значе- 
ния “по умолчанию" для нескольких последних 
аргументов. Эти значения будут использованы при 
вызове функции в случае, если соответствующие па- 
раметры окажутся опущенными. Для этого после име- 
ни аргумента через символ ' = ' указывается его зна- 
чение. 

Не забывайте, что здесь возможны конфликты при 
использовании механизма оѵегіоаб. 

Задать значения параметров можно только один 
раз, и лучше всего это сделать в разделе описаний. 

6. Ссылки 

В язык введен новый вид переменных — ссылки. 
Ссылка — это переменная, задаваемая указателем. 
Чтобы сделать переменную ссылкой, необходимо после 
описателя типа поставить оператор “&“. Ссылка во 
всем ведет себя так же, как и переменная того же 
типа, но при этом надо помнить, что на самом деле 
она совпадает с другой переменной, адрес которой 
указывается при объявлении ссылки. 

Вот пример: 

іп( а; 

іп( - &а\ 

Теперь переменная Ь совпадает с а. 


Даже начинающий программист сталкивался с си- 
туацией, когда в функцию необходимо передать не 
значение переменной, а ее адрес. Явная работа с ад- 
ресами вызывает неудобства и при разработке фун- 
кции, и при ее использовании. Теперь при описании 
функции достаточно указать, что параметр передается 
по ссылке, и работать с ним не как с адресом, а как с 
переменной. 

Вот как можно описать функцию пересчета декар- 
товых прямоугольных координат в полярные: 

ѵоід роіаг (сІоиЫе &х, (ІоиЫе &у, сІоиЫе &Гі, доиЫе &г){ 
г = 8^I1 (х*х + у*у) ; 

Гі = а1ап2 (у, х); 

} 

А вот как выглядит обращение к такой функции: 

СІоиЫе X, У, Р1, К; 
роіаг (X, У, Рі, К); 

Таким образом, незаметно для нас параметры переда- 
ются в функцию через их адреса. 

В приведенном примере переменные X и У тоже 
передаются по ссылке, хотя этого и не требует логика 
программы. Это сделано в целях экономии времени на 
их передачу, так как ссылка занимает четыре байта, а 
переменная типа сІоиЫе — восемь, и, передавая ее по 
ссылке, мы выигрываем вдвое (хотя в дальнейшем мы 
можем потерять время на обращении к этой перемен- 
ной). 

Самое интересное, что таким же образом можно за- 
дать и тип возвращаемого значения. Это приводит к 
эффекту на грани фокуса. Представьте себе, что у вас 
есть функция 

(ІоиЫе & Гипс (іп! і) ; 

Тогда вполне законной будет следующая запись: 

Гипс (10) = 1000.; 

Этот абсурдный на первый взгляд оператор имеет 
вполне конкретный смысл. Такой эффект мы исполь- 
зуем несколько позже. 

На пути к классам 

1. Функции — члены структуры 

Как правило, описав новую структуру, вы тут же 
создаете набор функций, работающих с этой структу- 
рой. Например, для структуры _3с1, описывающей 
трехмерный вектор, логично написать функцию 

СІоиЫе то(К_3(1 & х); , 

которая будет вычислять модуль вектора. Это — тра- 
диционный путь языка С. Вы описываете функцию, 
вычисляющую модуль вектора, который передается ей 
через формальные параметры. Между тем модуль — 
характеристика, присущая каждому вектору. Поэтому 
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будет логично, если вектор будет как бы сам возвра- 
щать свою длину. Эту абракадабру можно проиллю- 
стрировать следующим фрагментом программы: 

К; 

боиЫе а; 

а = шосКЮ; // Это традиционный подход 
а = К.шобО; // Это новый подход 

Здесь функция выступает как член структуры _3(І. На 
первый взгляд, различие незначительное. Однако 
отсутствие видимых преимуществ не означает отсут- 
ствия здравой идеи. Здесь может получиться так же, 
как и в истории со структурным программированием. 
Не видя явных выгод, этой идеей пренебрегали, пока 
ошибки не привели к миллиардным потерям. 

Для того чтобы функция стала членом структуры, 
достаточно поместить ее описание внутрь фигурных 
скобок, ограничивающих описание структуры. Напри- 
мер: 

5ІП1С! _3ё { 
боиЫе X, у, г; 
сІоиЫе ШОСІ О; 

}; 

При описании реализации функции надо после 
типа возвращаемого значения указать имя структуры, 
членом которой является данная функция, отделив от 
него имя функции двойным двоеточием — вот так: 

(ІоиЫе _3(1 :: шосІ О {геШгп (х*х + у*у + г*х)\] 

Можно поместить реализацию функции внутрь опи- 
сания структуры: 

8ІП1СІ { 

(іоиЫе X, у, г; 

(ІоиЫе шод О {геШгп зціі (х*х + у*у + х*г ) ;} 

}; 

в этом случае можно опустить имя структуры, а сама 
функция будет считаться іпИпе. Заметьте, что такая 
функция обращается с членами “своей“ структуры 
“запросто^* — по имени. 

Покончив с формой, перейдем к содержанию. На- 
ивно было бы думать, что создается новая копия фун- 
кции для каждой новой переменной данного типа. 
Каждая функция представлена в единственном экзем- 
пляре и получает один скрытый параметр — указатель 
на ту переменную, для которой она вызвана (будем 
называть ее рабочей переменной). К этому указателю 
можно обратиться по имени іЬіз. Если есть оператор 
а = К.то(Ю;, то ІНіз при этом вызове соответствует ад- 
ресу Я, а функция то(К) может быть реализована так: 

боиЫе _3с1 :: той О { 
геіигп 8^I1 (1ЬІ8- > х*!Ьі8- >х + 
иіі8->у*іЬІ8->у + 

!Ы 8 -> 2 *Ші 8 ->г);} 

Если переменная не описана ни внутри функции, 
ни как глобальная переменная, то считается, что она 


является членом структуры и принадлежит рабочей 
переменной •іЬіз. Поэтому можно опустить указатель 
1НІЗ и к членам структуры обращаться просто по 
имени. 

Даже если вы не считаете нужным описывать фун- 
кции как члены структур — к этому все же надо 
стремиться, так как такой подход создает несколько 
иной взгляд на программирование и формирует ваш 
стиль. В дальнейшем, когда речь пойдет об иерархии 
классов, механизме порождения и наследования, этот 
подход станет ключевым в понимании объектно-ори- 
ентированного программирования. 

Упражнение 1: 

Напишите функцию 

СІоиЫе _ЗсІ :: ргоесиоп (_3с1 г); , 

которая будет возвращать длину проекции вектора г 
на рабочий вектор. Проекция вектора А на В вычисля- 
ется по формуле 

(Ах*Вх + Ау*Ву + А 2 *Вг) / тод (В) 

Упражнение 2: 

Опишите структуру роіаг, определяющую вектор в 
полярных координатах г, П, 1. Для нее напишите фун- 
кцию 

_3(1 роіаг :: ѵесі О; , 

возвращающую рабочий вектор в декартовых коорди- 
натах. 

Упражнение 3: 

Приведите пример структуры С_ВиГГег, описыва- 
ющей кольцевой буфер емкостью 1024 действительных 
числа. Для нее опишите следующие функции: 

ѴОІСІ іпіі О ; // Инициализация 

ѵоісі асісі (сіоиЫе); // Добавить элемент 

(ІоиЫе О ; // Взять элемент 

іп! ГгееО; // Величина свободного пространства 

іп( изесіО; // Величина занятого пространства 

Решение 1: 

(ІоиЫе _3(І :: ргоесііоп (_3сі г){ 

геШт (х*г.х + у*г.у + г*г,г) / 8Ціі (х^х + у^у + г*г)\ 

}; 

Решение 2: 

8 ІП 1 С! роіаг { 

(ІоиЫе г, П, 1; 

_3(І ѵесі О; 

}; 

_за 

роіаг :: ѵесі О { 

(ІоиЫе с1 = со8(Гі), 8Г = 8іп(Гі), с1 = со8(1), 8І = 8іп(1); 

_3(і К; 

К.х = г*8Г*с1; 

К.у = г*8Г*8І; 

К .2 = г*сГ, 
геіит К; 

}; 
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Решение 3: 

Буферизация, или организация очереди, — широко 
распространенное техническое решение. Оно приме- 
няется, например, для согласования двух устройств 
или процессов, работающих в разном темпе. Один из 
способов реализации буфера — кольцевой буфер на 
одномерном ограниченном массиве. 

Идея заключается в следующем. Имеется одномер- 
ный массив и две индексные переменные. Одна — 
индекс приемника — указывает на элемент массива, 
куда записывается вновь поступающее значение. При 
записи индекс приемника увеличивается на единицу. 
Вторая — индекс источника — указывает на элемент 
массива, из которого извлекается значение. При 
извлечении индекс источника также увеличивается на 
единицу. Если один из индексов выходит за границу 
массива, то он устанавливается на его начало. В орга- 
низованной таким образом очереди могут “стоять“ не 
только действительные числа, но и объекты с более 
сложной структурой. 

В соответствии со всем вышесказанным опишем 
кольцевой буфер: 

8 ІП 1 СІ С_ВиГГег { 

(ІоиЫе ріг [1024]; // массив буфера 
ІПІ (1е$(, $гс; // ОЕЗТіпаІіоп — приемник 
// ЗоиКСе — источник 
ѵоШ ІПІ1 О {8ГС = (1е81 = 0;}; 
ѵоід л(\й (сІоиЫе а); 
сІоиЫе ^е1 О; 

ІПІ іі8есі О; 

ІПІ Ггее О; 

}: 

ѵоід С_ВиГГег :: асісі (сІоиЫе &а){ 
рй* [с1е8!++] = а; 
іГ (сіев! = = 1024) (1е8І = 0; 

}; 

СІоиЫе С_ВиГГег :: ^еі (){ 

іГ (-Н-8ГС ! = 1024) геПігп ріг [8гс-1]; 

8ГС = 0; 

геіигп ріг [1023]; 

}; 

ІПІ С_ВиГГег :: и8ед (){ 

ІПІ п = сіе8І-8гс; 
іМп > = 0) геіигп п; 
еІ8е геіигп п + 1024; 

}; 

ІПІ С_Ви[[ег :: Ггее (){ 

ІПІ п = 8гс-(іе8І; 
і^ (п > 0) геіигп п; 
еІ8е геіигп п + 1024; 

}; 

Функция іпіК) нужна для инициализации указате- 
лей. Обращение к ней обязательно перед использова- 
нием буфера. 

Пример с кольцевым буфером не является учебным. 
Аналогичная структура была использована автором в 
программах работы с модемом и с графопостроителем 
через последовательный порт К5-232. Предлагаемое 
решение вполне работоспособно и может использо- 
ваться в реальных программах. 


Вместе с тем это очень характерный и показатель- 
ный пример того, к чему нужно стремиться при напи- 
сании программ. При реализации этой структуры уда- 
лось добиться того, что ни массив, ни указатели не 
используются в программе в явном виде — все необ- 
ходимые операции выполняют функции. 

2. Операторы оѵегіоасі 

Раз уж мы ввели новый тип переменных — вектор, 
то было бы здорово иметь возможность записывать 
операции с векторами в виде выражений, например, 

_3(1 а, Ь, с; 

а = Ь + с; 

Язык С-н- предоставляет такую возможность. В при- 
веденном выражении символы ' = ' и являются опе- 
раторами, а операторы в С-н- рассматриваются как 
функции. 

Число операторов ограничено стандартным 
набором. Вновь вводимые операторы могут отличаться 
лишь типом участвующих в них операндов — отсюда 
и использование механизма оѵегіоасі. Ни приоритет, 
ни направление вычисления изменить нельзя. 
Оператор описывается так же, как и функция, только 
вместо имени функции пишется орегаіог $ (где $ — 
описываемый оператор). Вот пример описания 
оператора 

_3(і орегаіог (_3сі &а, _3сі &Ь){ 

__за с; 

с.х = а.х -ь Ь.х; 
с.у = а.у -ь Ь.у; 

С .2 = а. 2 + Ь. 2 ; 
геіигп с; 

) 

В качестве аргументов выступают операнды, а воз- 
вращаемое значение — результат применения опера- 
тора. Бинарные операторы имеют два аргумента, при- 
чем первому соответствует левый операнд, а вто- 
рому — правый. Унарные операторы имеют один ар- 
гумент. 

Чтобы можно было записать выражение, с которого 
мы начали этот раздел, надо определить оператор ' = '. 
Это бинарный оператор; в нем участвуют два опе- 
ранда, а возвратить он должен значение правого опе- 
ранда (именно такую трактовку имеет этот оператор в 
языках С и С-»--»-). 

_36& орегаіог = (_3сі &а, _ЗсІ &Ь) { 
а.х = Ь.х; 
а.у = Ь.у; 
а .2 = Ь. 2 ; 
геіигп а; 

} 

Здесь мы впервые возвращаем результат через 
ссылку. В данном случае мы можем себе это 
позволить, так как мы возвращаем ссылку на 
реальную переменную, существующую вне функции 


КомпьютерПресс 9'91 



языки ИСКУССТВЕННОГО ИНТЕЛЛЕКТА И ОБЪЕКТНО-ОРИЕНТИРОВАННОЕ ПРОГРАММИРОВАНИЕ 


47 


(ссылку на которую мы получили через параметры). 

Как и любая функция, оператор может быть членом 
структуры. Хотя это и не очевидно, но здесь тоже 
надо стремиться “встраивать** операторы в струк- 
туры — в дальнейшем это пригодится. Если оператор 
стал членом структуры, то число аргументов у него 
уменьшается — один из аргументов передается через 
переменную *ІНіз. Как уже говорилось, описание опе- 
раторов отличается от описания функций лишь име- 
нем, поэтому приведем пример операторов — членов 
структуры: 

8Ігисі _3(1 { 

доиЫе х, у, г; 
ёоиЫе тосЮ; 

_3(1 орегаіог + (_3с1 Ь); 

_3й & орегаюг = (_3с1 Ь); 

}; 

36 _ЗсІ :: орегаіог (_3с1 Ь){ 

_3(1 с; 

с.х = X Ь.х; 
с.у = у + Ь.у; 
с . 2 = 2 + Ь. 2 ; 
геШт с; 

) 

_36 & _3сі :: орегаіог = (_3с1 Ь){ 

X = Ь.х; 
у = Ь.у; 

2 = Ь.2*, 
геПіт ♦іНіз; 

} 

Все сказанное про функции со полным основанием 
можно отнести и к операторам. Различие заключается 
лишь в имени: имя функции меняется на орегаіог $ 
(где $ — определяемый оператор). 

Скажем немного о применении ссылки на возвра- 
щаемое значение. Предположим, что мы хотим обра- 
щаться к элементам вектора по индексу. Индексу О 
будет соответствовать х. 1 — у, 2 — 2. В этом случае 
мы можем определить следующий оператор: 

зігисі _3(1 { 

(ІоиЫе Аорегаіог () (іпі і){ге1ит ♦(&х і);}; 

); 

После этого законными и правильными будут следу- 
ющие выражения: 

_3(1 а; 
сІоиЫе X; 

X = а(0]; 

а[0] = X; 

Последнее выражение вызовет присваивание а.х зна- 
чения X. 

Приведем список операторов, которые можно пере- 
определять: 

11, О. ++, •. + . !. А %. <<,>>, 

<,>,<=,>=, = =,! = ,-, І.&&, 11. = ,♦ = , 

/ = ,% = . , 1=. 


На этом мы заканчиваем обсуждение ряда особен- 
ностей языка С++, не относящихся к его объектно- 
ориентированной специфике. Возможно, мы слишком 
долго не вводили понятия класса и объекта, зато нам 
удалось вынести за скобки дальнейшего изложения все 
детали и мелочи, затрудняющие понимание. 

Упражнение 4: 

Для структуры _3с1 определите операторы: 

— разность двух векторов, — угол между 
векторами, унарный ' = = ' — равенство векторов. 

Решение 4: 

8ігис1 _3с1 { 

СІоиЫе X, у, 2 ; 

(ІоиЫе тосІО; 

3(1 орегаіог + ( 36 Ь); 

_36 орегаіог - (_3с1 Ь); 

3(1 орегаіог - О; 

_3(1 & орегаіог = (_3с1 Ь); 

ІПІ орегаіог = = (_3с1 Ь); 

СІоиЫе &орегаІог [1 (іпі і){геіит ^(&х + і);); 

); 

_3с1 _3с1 :: орегаіог - (_3с1 Ь){ 

__3с1 с; 

с.х = х-Ь.х; 
с.у = у-Ь.у; 
с . 2 = 2 -Ь. 2 ; 
геШт с; 

) 

_3с1 _3с1 :: орегаіог - (){ 

_3с1 с; 
с.х = -х; 
с.у = -у; 
с . 2 = - 2 ; 
геіигп с; 

} 

ІПІ _3с1 :: орегаіог = = (_3с1 Ь){ 

геіит и= =Ь.х)&&(у= =Ь.у)&&( 2 = =Ь. 2 ); 

} 

Объектно-ориентированное 

программирование 

1. Понятие класса 

Самым интересным для нас нововведением С-»-+ бу- 
дет понятие класса. Ближайшим родственником 
класса является тривиальная структура. Если 
структуру наделить механизмом наследования, то она 
станет классом. Механизм наследования позволяет 
вновь создаваемым классам данных наследовать 
свойства уже существующих классов. Именно 
способность передавать и получать свои свойства по 
наследству отличает класс от структуры. 
Синтаксически класс описывается так же, как и 
структура: сначала идет ключевое слово сіазз, затем 
имя класса, затем, в фигурных скобках, члены 
класса — данные и функции. Все, что сказано о 
структурах, справедливо и для классов. Прежде чем 
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пользоваться механизмом наследования, преобразуем 
уже имеющуюся у нас структуру в класс: 

с1а58 _36 { 

риЫіс : 

боиЫе X, у, г; 

(іоиЫе той О; 

}; 

доиЫе :: той О { геПігп («яіКх^х + у*у + г*г)); }; 

Здесь описан класс с именем _ЗсІ. Ключевое слово 
риЫіс означает, что нижеследующие члены класса 
общедоступны. Далее описаны три действительных 
числа, задающих координаты вектора. Обращение к 
членам класса осуществляется так же, как и к членам 
структуры, — через точку. 

Для классов применяется несколько иная термино- 
логия. Если раньше мы говорили о переменной дан- 
ного типа, то теперь мы будем говорить об объекте 
данного класса, а функции — члены класса — будем 
называть методами данного класса. 

2. Конструкторы 
и деструкторы 

Создание объекта некоторого класса может быть до- 
статочно сложной процедурой. Поэтому в языке С++ 
предусмотрены возможности явного описания проце- 
дур создания и уничтожения объектов данного класса. 
Процедуры создания объектов называются конструкто- 
рами. Процедуры уничтожения — деструкторами. 
Конструкторы автоматически вызываются при описа- 
нии о^кта, а деструкторы — при выходе из блока, в 
котором этот объект был описан. Конструкторы в 
языке С-и- имеют имена, совпадающие с именем 
класса, и различаются между собой аргументами. Де- 
структор может быть только один и имеет имя, совпа- 
дающее с именем класса, которому предшествует сим- 
вол И конструкторы, и деструкторы не могут 
иметь описания типа. 

Обратимся к упражнению 3, где мы описывали 
кольцевой буфер. Там нам была нужна функция іпіі 
для того, чтобы проинициализировать индексы источ- 
ника и приемника. Эта функция обязательно должна 
была вызываться для каждой вновь создаваемой пере- 
менной этого типа. Если теперь мы преобразуем 
структуру С_ВиГГег в класс, то логично будет переде- 
лать функцию іпі! в конструктор. Это пример, когда 
конструктор просто необходим при описании класса. 
Более редкий случай — когда необходимо применение 
деструктора. Деструктор нужен, например, для осво- 
бождения динамической памяти, занятой объектом. 

Вот пример описания конструкторов класса _3(і: 

с1а88 _3сі { 

_3(1 (сІоиЫе &Х, сіоиЫе &Ѵ, боиЫе &Х) { х = X; у = V; г = 2;} 
_3(1 (_3(1 &а) { X = а.х; у = а.у; г = а.г; } 

}; 

Если необходимые конструкторы или деструктор 
для класса не описаны, то транслятор создает их сам. 
Вызов конкретного конструктора для создаваемого объ- 


екта происходит в зависимости от аргументов, которые 
могут быть указаны в круглых скобках после имени 
создаваемого объекта. Например: 

__3а А(0.,1.,0.),В; 

Здесь для объекта А будет вызван описанный нами 
конструктор _3<1 (боиЫе &Х, боиЫе &У, боиЫе &2), а 
для объекта В — созданный транслятором _3<1 О. 

Существует специальный тип конструктора, кото- 
рый вызывается при выходе из функции, если та воз- 
вращает объект данного класса. Дело в том, что все 
объекты, описанные внутри функции, разрушаются 
(для них вызывается деструктор) при выходе из нее. 
Такой конструктор нужен для того, чтобы скопировать 
результат до того, как он будет разрушен. Это необхо- 
димо, например, для объектов, использующих динами- 
ческую память. В качестве аргумента в этом конструк- 
торе выступает объект того же класса. Как было ска- 
зано выше, если этот конструктор не описан, то тран- 
слятор создает его сам. 

Упражнение 5: 

Часто требуется иметь буфер значительного объема. 
Поэтому нужно изменить описание класса С_ВиГГег 
так, чтобы можно было задавать объем буфера при его 
объявлении. 

Решение 5: 

В состав класса вводится дополнительное поле — 
длина буфера. Эта переменная подставляется везде 
вместо цифры 1024. Кроме того, вводится конструк- 
тор, который размещает массив ріг, и деструктор, ко- 
торый его освобождает. 

сіазв С_Ви1Гег { 
риЫіс : 

(ІоиЫе ♦ріг; // массив буфера 
ІШ (1е$!,$гс; // ОЕЗТіпаІіоп — приемник 

// ЗоиВСе — источник 
ііИ Іеп; // длина 6у())ера 
С_ВиГГег (іпі _1еп = 1024); 

-С_ВиГГег О {іГ (р»г ! = ЫУШ Ггее (ріг);} 
ѵоісі асісі ((ІоиЫе а); 

(ІоиЫе ^еі О; 
іп( и8е(і О; 
іп! Ігее О; 

}; 

С ВиГГег :: С^ВиГГег (ііИ _1еп) { 

Іеп = _1еп; 

(1еа< = 8ГС = 0; 

ри*= ((ІоиЫе *) шаііос (Іеп^віхеоПсІоиЫе)); 
іГ (рь* = = N^^^) Іеп = 0; 

} 

ѵоі(І С_ВиГГег :: а(1(і (сІоиЫе &а){ 
р!г [сіеві-н-і = а; 
іГ ((Іезі = = Іеп) 6е&\ = 0; 

}; 

(ІоиЫе С_Ви1Гег :: ^еі (){ 

іГ (-Н-8ГС ! = Іеп) геШт ріг [8гс-11; 

8ГС = 0; 

геШт ріг [Іеп- 11; 
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іп( С_ВиГГег :: ивесі (){ 
іп( п = (іе5(-$гс; 
іГ (п > = О) геПіш п; 
еІ8е геПіш п -і- Іеп; 

}; 

іт С__ВиГГег :: Ггее (){ 
іп! п = 8гс-(1е8!; 
іГ (п > 0) геПіш п; 
еІ8е геПігп п + Іеп; 

}; 

3. Правила доступности членов класса 

При описании класса можно определять доступ- 
ность членов класса для “чужих** функций. Вообще, в 
объектном программировании считается хорошим то- 
ном закрывать все данные и служебные методы опи- 
сываемого класса для доступа **извне**. 

Так, в примере с кольцевым буфером логично за- 
крыть для доступа массив и оба указателя, чтобы с 
ними можно было работать только через методы абсі и 
^еі. Описывая класс, нужно оставлять доступ только к 
тем членам класса, которые необходимы для коррект- 
ной работы с объектами; всю сколько-нибудь сложную 
работу должны брать на себя методы данного класса. 

В С-н- существуют три служебных слова, определя- 
ющих доступность членов класса. С первым из них вы 
уже встречались — это слово риЫіс. Если вы напи- 
шете это слово и поставите после него двоеточие, то 
все нижеследующие члены класса будут считаться 
общедоступными, пока не встретится другое описание 
доступности. 

Другое слово — ргоіесіеб. Это слово определяет, 
что члены класса доступны только дружественным 
функциям и классам, а также классам-наследникам 
данного класса. 

Слово ргіѵаіе ограничивает круг **посвященных** 
только дружественными функциями и классами. 

Дружественные функции и классы — это функции 
и классы, упомянутые внутри описания класса с опи- 
сателем Ггіепб. Это слово ставится самым первым в 
описании такой функции или класса. 

Упражнение 6: 

Ограничьте доступ к членам класса С__ВиГ?ег так, 
как описано выше. 

Решение 6: 
сІа88 С_ВиГГег { 
ргоіесіесі : 

сІоиЫе *ріг; // массив буфера 
ІПІ с1е8!,$гс; // ОЕЗТіпаііоп — приемник 

// ЗоиНСе — источник 
іт Іеп; // длина буфера 
риЫіс : 

С^ВиГГег (іп! _1еп = 1024); 

-С_ВиГГег О {іГ (ріг ! = N^^^) Ггее (р!г);) 
ѵоіс) л66 (сІоиЫе а); 

(ІоиЫе ^е( О; 
іт изесі О; 
іт Ггее О; 

іт Іеп^іН О {геіит Іеп;) 

); 


Метод Іел^ГНО позволяет проверить размещение мас- 
сива. 

4. Механизм наследования 

Наследование заключается в том, что для вновь со- 
здаваемого класса мы можем указать классы, от кото- 
рых он наследует их данные и методы. Такие классы 
мы будем называть предками, или порождающими 
классами, а новый класс — наследником, или порож- 
даемым классом. Как правило, порождаемый класс 
имеет лишь одного предка. Иногда идеология задачи 
требует создания мощного дерева иерархии классов. 
Механизм наследования хорош отнюдь не тем, что он 
позволяет не описывать наследуемых членов класса. 
Дело в том, что транслятор выполняет скрытое преоб- 
разование типов **сверху вниз**, то есть о(Ь>ект- наслед- 
ник **сходит** за своего родителя. Иначе говоря, фун- 
кции, работающие с объектами класса-п редка, будут с 
тем же успехом работать и с объектами класса-на- 
следника. При этом ** наследи ики“ ведут себя анало- 
гично **предкам**. 

Для того чтобы задать отношения наследования 
между классами, надо при описании нового класса по- 
сле имени класса поставить двоеточие и далее пере- 
числить через запятую имена предков. 

Предположим, что мы хотим ввести новый класс 
соогб, описывающий систему координат в декартовом 
пространстве. Любая система координат задается по- 
ложением центра и направлением осей. Так как центр 
системы координат задается вектором, то желательно, 
чтобы в некоторых случаях объекты класса соогсі вели 
себя аналогично объектам класса _3б. Вот пример 
описания класса соогсі: 

с1а88 СООГСІ : риЫіс _3с1 { 

риЫіс : 

_за х,ѵ,г; 

}; 

Здесь описан класс- наел ед ник класса _3с1. Слово 
риЫіс перед именем класса-предка говорит о том, что 
общедоступные члены предка, наследуемые порожда- 
емым классом, также общедоступны. Членами класса 
СООГСІ являются действительные х, у, г координаты 
центра (наследуемые) и три вектора X, V. 2, зада- 
ющие направление осей в пространстве. Объект этого 
класса может работать и как вектор. В этом случае он 
представляет собой положение центра системы коор- 
динат. 

Упражнение 7: 

Используя класс ВАЗЕ^УзІ, приведенный в прило- 
жении, опишите класс ОоиЫеУзІ, реализующий спи- 
сок из действительных чисел. 

Решение 7: 

Рассмотрим абстрактный класс ВА5Е_и8І, приве- 
денный в приложении. Этот класс реализует двуна- 
правленный список. Список — это последовательность 
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объектов некоторого класса, называемых его элемен- 
тами. В любой момент времени доступно не более 
одного элемента списка. Доступ к другим элементам 
можно получить, последовательно перемещаясь от 
одного элемента к другому, к концу списка или к его 
началу. При этом возможны три особых состояния: 
список пуст, доступный элемент в начале списка, до- 
ступный элемент в конце списка. 

Возможна вставка нового элемента перед доступным 
элементом или после него. Для этого служит метод 

ІП8 (іпі І,іт Ье^оге); , 

где I — длина вставляемого элемента, Ье^оге — указы- 
вает на то, что элемент должен вставляться перед до- 
ступным, если ЬеГоге отлично от нуля, и за ним — 
если равно. Вставленный элемент становится теку- 
щим. Доступный элемент можно удалить; для этого 
служит метод беі О;. При этом становится доступным 
следующий к концу элемент (если его нет, то преды- 
дущий). 

Для перемещения от одного элемента к другому 
используются операторы: '-н-' — от начала к концу, 

' — от конца к началу. Метод ѵоіб *оЬ]ес! О; воз- 
вращает адрес текущего элемента. 

Более подробно описание этого класса см. в прило- 
жении. 

Решение заключается в том, чтобы сделать более 
простым доступ к текущему элементу и упростить 
вставку. 

с1а5$ ПоиЫеЬі5( : ѵігПіаІ риЫіс ВАЗЕ_ІІ8! { 

риЫіс : 

іт іп$ (ііК ЬеГг = 1 ) { 

геПіт ВА8 Е_іі8і :: іп 8 ( 8 І 2 еоГ(ТѴРЕ), ЬеГг); 

} 

боиЫе& орегаіог • О { 
геПіш ♦((сІоиЫе ♦)оЬ)ес!()); 



5. Виртуальные методы 

Как же быть, если мы хотим, чтобы “наследи ик“ 
вел себя отлично от “предка**, сохраняя при этом 
свойство совместимости с ним? На этот случай суще- 
ствуют виртуальные методы. 

Виртуальный метод — это метод, который, будучи 
описан в потомках, замещает собой соответствующий 
метод везде — даже в методах, описанных для предка, 
если они вызываются для потомка. 

Необходимость в применении виртуальных методов 
возникает, если существует набор классов, облада- 
ющих схожими по смыслу методами, различающимися 
лишь реализацией (методы А), и если существуют 
идентичные по реализации методы, использующие ме- 
тоды А (методы Б). В этом случае описывается базо- 
вый класс, для которого описываются виртуальные ме- 
тоды А. Как правило, методы А не конкретизируются 
(ставятся заглушки). После этого описываются методы 
Б, использующие методы А базового класса. Затем 


описываются производные классы, в которых методы А 
конкретизируются. 

Возможен и другой взгляд на виртуальные методы. 
Предположим, что можно описать класс-концепцию, 
который послужит базовым классом. Если для класса- 
концепции можно указать методы, которые будут 
иметь различную реализацию в производных классах, 
то их делают виртуальными. Виртуальные методы 
производных классов заменяют методы базового класса 
везде, где они упоминаются. 

Чтобы метод был описан как виртуальный, нужно 
перед его описанием поместить слово ѵігіиаі. 

Проиллюстрируем все это на примере графических 
объектов. Опишем класс СгарНісзОЬ]ес<. Этот класс 
имеет методы Виііб — построить, Оізріау — показать, 
Ніб — скрыть и Моѵе — переместить. Идея этого 
класса заключается в том, чтобы можно было переме- 
щать графические изображения по экрану не изменяя 
его содержимого. 

Метод Оізріау запоминает изображение в некоторой 
области памяти и вызывает метод Виіісі, который в 
этой области строит новое изображение. Метод Ніб 
скрывает изображение, построенное методом Виіісі, 
восстанавливая то изображение, которое запомнил ме- 
тод Оізріау. Наконец, метод Моѵе вызывает метод Нісі, 
чтобы скрыть старое изображение, и метод Оізріау, 
чтобы построить его на новом месте. 

Объявим метод Виіісі виртуальным. Опишем теперь 
двух потомков класса СгарНісзОЬ]ес1. Первый — Сіг- 
сіе — имеет метод Виіісі, который строит кружок. 
Второй — Еесіап^іе — имеет метод Виіісі, который 
строит прямоугольник. Все! Если теперь мы объявим 

Сігсіе А; 

Кесіап^іе В; 

то вызывая методы Оізріау, Нісі и Моѵе для объекта А, 
мы будем работать с кружком, а для объекта В — с 
прямоугольником. 

// Описание класса СгарНіс80Ь]есІ 
с1а88 СгарНіс80Ь]ес< { 
ргоіесіесі: 
ііИ X, _у; 

ѴОІСІ *іта^е; 

риЫіс: 

ѵоісІ Оізріау (іп! X, іпі у); 
ѵіПиаІ ѴОІСІ Виіісі (іпі х, іпі у); 

ѴОІСІ НІСІ О; 

ѴОІСІ Моѵе (ІПІ X, іпі у); 

}; 

// Описание класса Сігсіе 
сіазз Сігсіе : ѵіПиаІ риЫіс СгарНіс80Ь]есі{ 
ѵіПиаІ ѴОІСІ ВиіШ (іпі х, іпі у); 

// метод строит кружок 

}; 

// Описание класса Кесіап^іе 
сіазз Кесіап^іе : ѵігіиаі риЫіс СгарЫсзОЬ)есі{ 
ѵіПиаІ ѴОІСІ Виіісі (іпі х, іпі у); 

// метод строит прямоугольник 

); 
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Если бы метод ВиіМ не был объявлен виртуальным, 
то при вызове А.ОізрІау вызывался бы метод 

ОгарНіс$ОЬ]ес! :: ВшШ (іпі,іпО; 

Но поскольку Виіісі — виртуальный, то вызывается 
Сігсіе :: Виіісі (іпі,іпО; 

Как же реализуется механизм виртуальных мето- 
дов? Каждый объект, помимо полей данных, описан- 
ных для данного класса, содержит ссылку на таблицу 
адресов виртуальных методов своего класса. При вы- 
зове виртуального метода его адрес извлекается из со- 
ответствующей данному объекту таблицы — таким 
образом вызывается “то, что надо“. Объекты 
“таскают** свои виртуальные методы с собой. 


Вот и все. Конечно, изложенный материал плохо 
согласуется со сложившейся практикой программиро- 
вания. Объектно-ориентированное программирование 
станет, возможно, самым ценным приобретением ал- 
горитмических языков за всю их предыдущую исто- 
рию. Новые идеи требуют слишком радикального 
изменения взглядов и подходов к программированию. 
Применять объектное программирование нужно начи- 
нать постепенно, исподволь, там, где этого вроде и не 
требуется — это позволит во всеоружии подойти к бо- 
лее серьезным задачам. Не нужно, бояться экспери- 
ментировать и применять новое. Помните, что сме- 
лость не только города берет, но и помогает осваивать 
С++. 

А.Матвеев 


Компания Сопѵех Сотриіег 
Согрогаііоп выпустила то, что 
она называет первым коммерчес- 
ким визуальным отладчиком, 
способным анализировать сильно 
оптимизированный код програм- 
мы на уровне языков высокого 
уровня. 

Новый продукт, названный 
СХбЬ, может работать с прог- 
раммами на РОКТКАН'е и С с 
использованием оконного интер- 
фейса на графических термина- 
лах в среде системы СX^Vіп<^о^ѵ8. 
Пользователь может в разных 
окнах одновременно видеть объ- 
ектный код, исходный текст и 
результат работы программы. Он 
также получает доступ ко всем 
системным ресурсам. 

СХсІЬ продается с начала 
июля. Минимальная цена — 
9500 долларов. Сопѵех произво- 
дит суперкомпьютеры, предназ- 
наченные в основном для техни- 
ческих и научных нужд. 

МешЪуіез МеШ)гк, 
19 Іиіу, 1991 

Президент фирмы Вогіапсі 
Филипп Кан высказал свою точ- 
ку зрения на продолжающиеся 
судебные процессы между Вог- 
іапсі и Еоіиз, а также между 
АзЫоп-ТаІе и Рох БоПлѵаге на 


собрании группы пользователей 
ІВМ в Пасадене, Калифорния. 

По слова Кана, оба дела тесно 
связаны между собой. В обоих 
случая истец, Еоіиз и АзЫоп- 
Таіе, пытаются защитить автор- 
ским правом не новое изобрете- 
ние, а иерархическую структуру 
команд, определенную самим 
функционированием программы. 

Он добавил, что компании 
могли бы получить патент на 
свои творения, но они стремятся 
заполучить исключительные 
права на то, что, по мнению 
президента фирмы, не может за- 
щищаться никаким авторским 
правом. 

Если истцы выиграют процес- 
сы, это может изменить не толь- 
ко компьютерную индустрию, но 
и весь товарный рынок. Внезап- 
но производитель самолетов зая- 
вит, что он обладает авторскими 
правами на размещение органов 
управления в пилотской кабине, 
чем заставит других производи- 
телей располагать их по-друго- 
му. Видеомагнитофоны, телеви- 
зоры, все имеют иерархию ко- 
манд, базирующуюся на выпол- 
няемых ими функциях. Если эти 
команды станут объектом автор- 
ского права, то автоматически 
каждый новый производитель 
будет вынужден выдумывать 


свои команды, делая пользова- 
ние устройствами нескольких 
фирм почти невозможным. 

**Если иерархия команд, осно- 
ванная на функциональных 
свойствах будет защищаться ав- 
торским правом, это будет ката- 
строфой**,- сказал Филипп Кан. 

Он добавил, что Вогіапсі мог 
бы платить фирме Еоіиз неболь- 
шие отчисления за использова- 
ние популярного командного ин- 
терфейса, но Ьоіиз хочет добить- 
ся судебного решения о том, что 
они являются собственниками 
этих команд и никто кроме них 
не может их использовать. 

“Мы, конечно, можем просто 
убрать этот дополнительный эле- 
мент из РиаИго Рго, и большин- 
ство наших пользователей от 
этого не пострадает. Но теперь 
для нас этот процесс стал просто 
принципиальным**. 

Комментируя процесс между 
АзЫоп-ТаІе и Рох ЗоНѵѵаге, Кан 
ехидно отозвался об адвокатах 
обеих сторон и сказал, что они 
не скандальная компания и с 
Рох договорятся быстро. 

Ранее в июле Вогіапсі объявил 
о намерении купить фирму АзН- 
іоп-Таіе. А затем и сделал это. 

Ме\ѵ8ЬуІв8 Ые\ѵ8 Меімюгк, 
23 /иіу, 1991 
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СОВРЕМЕННЫЕ МЕТОДЫ ПРОМЫШЛЕННОЙ РАЗРАБОТКИ ПРОГРАММНОГО ОБЕСПЕЧЕНИЯ 



ІГкауки, связанные с вычислительной 
техникой, стареют, и идеи, которые 
развивались в 60-е и 70-е годы, сегодня 
являются лишь элементарной основой 
идей и методов/' 

Дж.Ульман “Сотри(а(іопа1 а$рес(5 оГ ѴЬ8І“, 
Сотриіег 8сіеп$е Рге55, 1987. 


СОВРЕМЕННЫЕ МЕТОДЫ 
ПРОМЫШЛЕННОЙ РАЗРАБОТКИ 
ПРОГРАММНОГО ОБЕСПЕЧЕНИЯ 


Чтобы немного прояснить разницу между 
современностью и недалеким прошлым, я позволю 
себе перечислить некоторые основные достижения в 
науке о программном обеспечении компьютеров, 
которые сейчас позволяют нам работать более 
производительно и более уверенно смотреть в будущее. 

К концу 70-х годов был достигнут ряд важных ре- 
зультатов: 

- создание формальной теории проектирования компи- 
ляторов с алгоритмических языков; 

- формирование концепции абстрактных типов дан- 
ных; 

- разделение программного обеспечения на аппаратно- 
зависимую и проблемно-зависимую части; 

- создание переносимой операционной системы ІіМХ и 
переносимого языка С; 

- разработка унифицированных гипііте-интерфейсов 
для прикладных программ (АРІ) и стандартных 
форматов обмена данными. 

Между тем, растущее применение компьютеров (в 
особенности персональных) в самых различных облас- 
тях приводило к росту потребности в разработке прог- 
раммного обеспечения. 

В 70-е годы стало ясно, что прогресс в области сис- 
темного программирования должен быть распростра- 
нен и на методы разработки прикладного ПО. Таким 


распространением явилось внедрение в практику воз- 
никшей на основе концепции абстрактных типов дан- 
ных технологии объектно-ориентированного програм- 
мирования. 

Объектно ориентированное программирование — не 
новый термин. Мы слышим о системах ООП уже с 
конца 70-х годов. Но подлинное десятилетие ООП на- 
чалось только сейчас, с созданием и широким внедре- 
нием эффективных объектно-ориентированных язы- 
ков, таких как С-и- и объектно-ориентированных вер- 
сий Разсаі. 

Объектно-ориентированные языки 70-х (например, 
такие как ЗтаІИаІк) опирались на мощные и громозд- 
кие интегрированные среды и реализовывались в зна- 
чительной мере на принципах интерпретации. На се- 
годняшний же день основным языком ООП стал С++, 
созданный группой под руководством Бьерна Страуст- 
рупа из Веіі ЬаЬогаЮгіез (АТ&Т, ПЗА). Значение этой 
разработки нужно рассматривать исходя из того, что 
впервые была предложена стандартная, базирующаяся 
на синтаксисе переносимого языка, форма для кодиро- 
вания объектов и их методов. Более того, идеология 
С++ была нацелена на то, чтобы все операций по свя- 
зыванию объектов и манипулирующих ими методов 
выполнялись во время компиляции. В результате того, 
что в С-н- механизм скрытия данных работает во вре- 
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мя компиляции, получающаяся исполняемая програм- 
ма (.ехе файл) не содержит ничего лишнего (напри- 
мер, “монитора виртуальных объектов** или *‘динами- 
ческого интерпретатора методов класса**). 

Продолжающееся успешное внедрение С-н- техноло- 
гии в коммерческие программы позволяет с увереннос- 
тью утверждать, что язык С++ стал основным средст- 
вом разработки программных систем, ориентирован- 
ных на конечного пользователя. 

Системами, ориентированными на конечного поль- 
зователя, автор называет программные системы, кото- 
рые могут быть быстро освоены персоналом с мини- 
мальными навыками работы с компьютером (это такие 
системы, как бВАЗЕ, Сііррег, АСАО, Ргате^огк 
и Т.Д.). Язык С++ является средством разработки по- 
добных систем. 

Некоторые уже достаточно хорошо известные зару- 
бежные программные разработки имеют вполне отчет- 
ливый “привкус** С++. Еще одним примером успешно- 
го применения методов ООП в индустрии программно- 
го обеспечения может служить создание в недавнее 
время целого ряда специализированных генераторов 
исходных текстов программ или их частей (это реали- 
зуется путем компоновки объектов из библиотеки). 
Возьмем, например, построитель интерфейса в систе- 
ме ПО компьютера N6X7. Эта программа позволяет 
описывать пользовательский интерфейс прикладной 
программы, оперируя понятиями вида: окно, функ- 
циональная клавиша, меню и т.д. Построитель ин- 
терфейса N6X7 генерирует на выходе исходный текст 
на диалекте С++. Другим примером может служить 
возможно уже знакомый читателю построитель ин- 
терфейса из пакета 7игЬо Разсаі 6.0. Джефф Уол- 
ден! 11], описывая пакет ТооІЬоок фирмы Азутеігіх, 
который “позволяет строить свою программу, компо- 
нуя стандартные объекты**, говорит о целом ряде 
аналогичных продуктов конкурирующих фирм. 

Хочу обратить внимание читателя на то, что время 
подобных построителей (к слову сказать, существен- 
но облегчающих жизнь их покупателям) пришло с 
внедрением ООП. Овладев одним из современных 
языков ООП (например, ХогІесН С-н-, Вог- 
Іапсі С-ь-»- 2.0 или 7игЬо Разсаі 5.5), вы сами почувст- 
вуете, с какой легкостью могут быть написаны по- 
добные программы. Время “построителей** (причем 
не только интерфейсов пользователя) пришло с 
внедрением С-н-. Чтобы в какой-то мере проиллюст- 
рировать технологию программирования с использо- 
ванием объектно-ориентированного подхода, 
предлагаем вам пример разработки небольшой 
программы на С-н-. 

Допустим, мы хотим разработать программу, реали- 
зующую простейшие функции меню интерфейса. Что 
нам нужно для этой программы? Очевидно, необходим 
объект меню. Какие действия можно выполнять с ме- 
ню? Например, следующие: 

- создать пустое меню; 

- добавить строку к меню; 

- нарисовать меню на экране дисплея; 


- производить выбор пунктов меню (точнее, передать 
управление меню пользователю за клавиатурой); 

- удалить меню с экрана. 

Преимущество объектно-ориентированного подхода 
состоит в том, что он позволяет нам рассматривать та- 
кой сложный объект, как меню, в качестве элементар- 
ного типа данных. С этим объектом мы можем опери- 
ровать так же просто, как с обычной переменной, 
описанной, например, так: 

ІПІ ] ; 

В принципе, меню — такой же простой объект, как 
и любая переменная. Сущность меню определяется 
действиями, которые можно над ним выполнять. Дейс- 
твия над объектом в С-и- называются методами. Нам 
необходимо определить эти методы формально, т.е. 
запрограммировать их. 

Для того чтобы запрограммировать все перечислен- 
ные выше методы, нам понадобятся некоторые дан- 
ные, отражающие содержимое и текущее состояние 
меню. Эти данные включают в себя следующие эле- 
менты: 

- массив строк меню; 

- текущее число строк в меню; 

- номер текущей (подсвеченной) строки меню; 

- координаты левого верхнего угла меню на экране; 

- код нажатой пользователем клавиши. 

Язык С-н- позволяет нам рассматривать данные объ- 
екта и методы объекта совместно. Закодировав дан- 
ные, и запрограммировав методы, мы определим не 
просто отдельный объект меню, а любое произвольное 
меню. Мы зададим целый класс объектов. Совокуп- 
ность данных и оперирующих ими методов в С-н офо- 
рмляется специальным образом синтаксически и назы- 
вается описанием класса. 

Составим описание класса меню в синтаксической 
нотации Сн. 

с1»м ю-“ііи_ѵегі 
{ 

ргі\«1е: 

іпі ж ; // Текущий левый верхний угол меню 

іпі у ; 

ІПІ ргевеоМіеш ; // Номер текущей строки меню 

ІПІ питЬе^оМіет ; // Текущее число строк меню 

ІПІ ж шісНЬ*'; ~ // Шириив меню 

ІПІ {ГоЬ_тепи_кеу ; // Выбирающая клавиша 

ІПІ {1оЬ~тепи~іІет ; // Номер выбранной строки меню 

сЬаг ііет(МЛХ_1ТЕМ_^АМОиі^](>^Х.П'ЕМ.Ш1І>ТН) ; // Строки меню 
риЫіс: ” ” ” “ 

ѵоісі іаіІ() ; // Инициализировать пустое меню 

ѵоісі а<к1_ііет( сЬаг *веѵііет ) ; // Добавить строку в меню 
ѴОІСІ <1гаѵ_теви() ; // Нарисовать меню на экране 

ѵоі<І теа«СсЬоісе() ; // Выбирать меню 

ѵоі<1 егаае~тепи() ; // Стереть меню с экрана 

ѴОІСІ жеі_піёои_ху( іві іпх , іві іву ) ; // Установить положение 
// меню на экране 

ІПІ (еі_^ІоЬ_теои_іІет() ; // Получить номер выбранной строки меню 

ІПІ ^еІ_§1оЬ~тепи~кеу() ; // Получить код клавиши, которой 

и производился выбор (например, Еас или Епіег) 

Все, что описано выше слова риЫіс является скры- 
тым в меню и недоступным для любого участка прог- 
раммы. Доступны лишь методы класса, описанные ни- 
же риЫіс. Полностью программа приведена в прило- 
жении к статье. Там вы найдете и реализацию мето- 
дов класса тепи_ѵегІ. А здесь мы покажем, как легко 
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СОВРЕМЕННЫЕ МЕТОДЫ ПРОМЫШЛЕННОЙ РАЗРАБОТКИ ПРОГРАММНОГО ОБЕСПЕЧЕНИЯ 


теперь использовать в программе самые разнообразные 
меню. 

Допустим, мы хотим создать меню оболочки компи- 
лятора. Нет ничего проще, ведь у нас уже есть класс 
меню. 


тяіп() 


тепи_ѵег( тЬссН , жЬс<12 , аЬссІЗ ; // Опишем той меню 

// Не правда ди, не сложнее чем **іпІ і, ], кг? 


аЬс<11.іпі(() ; 
аЬсс11д<)(]_йет( 

аЬс(] 1 д <1с)3 (с™ ( 

аЬс(11.а<І(]_і(ет( 
аЬс<11.ас1(]~іІеті 
аЬс(11д<1<іЗ<ет{ 
аЬсіП д (]()_іІет { 
аЬс(]1д(1<іЗ(ст( 
аЬс<і1де( тепи 


// Инициализируем первое меню 

“ЗАГРУЗИТЬ") ; 

“НОВЫЙ ФАЙЛ") ; 

“СОХРАНИТЬ") ; 

“ЗАПИСАТЬ в ...“) ; 

“КАТАЛОГ") ; 

“ВЫХОД в 005") ; 

“ПОКИНУТЬ - АН X") ; 

_*У(М) ; 


ботанных алгоритмов. Этим целям, в частности, слу- 
жит механизм наследования классов и виртуальных 
функций. Возможности хорошо написанной объектно- 
ориентированной программы на С++ могут быть су- 
щественно расширены или изменены, с модификация- 
ми исходного текста на порядок меньшими, чем, нап- 
ример, при использовании обычного (не 00) языка 
программирования. С-н- позволяет писать очень гибкие 
программы. В связи с этим давайте вернемся к наше- 
му примеру с меню. 

Представьте себе, что вам теперь необходимо иметь 
меню не из текстовых строк, а из графических изобра- 
жений на экране дисплея. Данные и методы класса 
для графического меню почти так же просты, как и 
для текстового. Например, этот класс может быть та- 


жЬс(12.ііііІ() ; // Инициализируем второе меню 

лЬсйІлбб іІет(“КОНТРОЛЬ СКОБОК") ; 
аЬс<!2да<і“іІет(“КОНТРОЛЬ СИНТАКСИСА") ; 
аЬс<12д(]<І_і(еіп(“ВЫПОЛНИТЬ ПРОГРАММУ") ; 
аЬс<12леі_тепи_ху(20,1) 

аЬс(13.іпіІ() ; // Инициализируем третье меню 

лЬсаЗлМ іІетГСПИСОК СИНТАКСИЧЕСКИХ ОШИБОК") ; 
аЬс(13д<1(і~і(ет("ИСПОЛЬЗОВАННЫЕ ЛИТЕРАЛЫ") ; 
аЬс(13д(1с]''іІет("ИСПОЛЬЗОВАННЫЕ КОНСТАНТЬІ") ; 
аЬс(13дс1(1~іІет("ИСПОЛЬЗОВАННЫЕ СТАНДАРТНЫЕ ФУНКЦИИ") ; 
аЬс(!Зд()<І~і(ет("ФУНКЦИИ ПОЛЬЗОВАТЕЛЯ") ; 
аЬсс13ле(_тепи_ху(43,1) ; 


// Теперь, если пользователь должен вступить в диалог с меню 2 
аЬс<12.(1гавг_тепи() ; // Нарисуем меню, 

аЬсс12.тепи_сЬоісеО ; // затем передадим управление пользователю 

” //Так же просто, как “і-і+1 

імег_*(гів(^питЬег - ^еІ_^ІоЬ_тепи_кеу() ; // Получаем результат 
и»ег”кеу - (е(_^ІоЬ_тепи_і(еіп() ; ~ // диалога с пользователем 

аЬс<12.егаае_^тепи() ; // Удаляем меню 

іі ( исег_*1пв|^пиЬтег и тл. 


КИМ: 


сіам в1і<Іе_тепи 

{ 

ргіѵаіе: 

сЬаг «1Ь_Гі1е_пате[РІГЕЫАМЕ ГЕНОТН] ; // Имя файла, содержащего 

//библиотеку изображений пунктов меню 
іп( тах_іІет ; // Реальное текущее число 

** // установленных пунктов меню 

іпі ргеаепМіет ; // Текущий пункт для тепи_сЬоісе 

•1сі_тепи_іІет *іІетс[МАХ_ГГЕМ$ АМОІЛЧТ] ; // Изображ’ёния меню 
іві ге(_соЗе«[МАХ_ІТЕМ$__АМОІІМТ] ; // Коды, возвращаемые 

~ ~ ~ // вызывающей программе 

риЫіс: 

•1і<1е_тепи( сЬаг ‘вШ^Г^в ) ; // Создать і^стое меню 

ѵоіс1*іеІ_е1()_і(ет( сЕсІ^йспи^йет *х , іпі геІ_с ) ; // Добавить 

~ //“изображение в меню 

ІПІ Сі11_тепи( іприІ_ЬиССег ДЬиГГеге<1_>1Ь ) ; // Заполнить адреса поиска 
” ~ // (найти адреса всех изображений 

// меню в оглавлении библиотеки) 
ѵоій (1гаю_тепи ( іприі_ЬиГГег АЬиПеге(1_*1Ь // Нарисовать меню 
ІПІ тепи_сЬоісе(іпІ Акеу сойс ) ; // Выбирать меню 

// (возвращает текущий выбранный пункт 
// и код выбирающей клавиши) 
ѵоісі тепи_ега<е() ; // Удалить меню 

}; 


Вся утомительная возня с массивами и счетчиками 
по модулю N скрыта внутри методов класса, причем 
она автоматически воспроизводится, стоит лишь опи- 
сать новую переменную меню. 

Класс в С-и- наиболее близок к шаблону структуры 
в языке С. Переменные структурного типа (как аЬссИ, 
аЬсс12, аЬсбЗ) называются экземплярами класса. Отли- 
чие классов в С++ от структур в С заключается в том, 
что в С-н- область видимости переменных, принадле- 
жащих структуре-экземпляру класса, находится ис- 
ключительно внутри методов класса. Т.е. идентифика- 
торы ргезепМіегп, х_\ѵісИН и т.д. имеют смысл только 
внутри функций: іпіК ),..., 5е1_^1оЬ_тепи_кеу(). При- 
чем вызов аЬссП.іпіК) оперирует с аЬссП.ргезепМіеш, 
а вызов аЬсс12.іпіЮ с аЬс(12.рге5епІ_ііет и т.п. 

Вызов аЬсс12.іпіЮ означает, что функция 
тепи_ѵегІ::іпИ() получает в качестве параметра указа- 
тель на аЬссІ2, — экземпляр класса тепи_ѵег1. 

Так работает механизм скрытия данных С-н-. Скры- 
тие данных позволяет избежать многих видов ошибок, 
сохраняет концептуальную целостность объектов, про- 
ясняет структуру больших программ. 

Умело применяя механизм скрытия, можно писать 
довольно сложные программы, оперирующие сложно- 
структурированными данными. Причем на С-н- такие 
программы можно писать достаточно быстро. С-н- зна- 
чительно повышает повторную используемость разра- 


Назначение методов аналогично текстовому меню: 
создать пустое меню, добавить пункт, нарисовать ме- 
ню, выбирать пункт меню. Отличие в том, что сам 
пункт графического меню представляет собой более 
сложную структуру — экземпляр класса 
8Іс1_тепи_іІет. Спецификация этого класса приведена 
ниже: 


сіам ж1(1_тепи ііеш 

( 

ргіѵаіе: 

сЬаг тетЬег_*1Ь_пате[МАХСННІІМ] ; // Имя изображения в каталоге 
~ ~ // библиотеки 

1оп{ жеек_а()(]г_іп_ж1Ь ; // Стартовый адрес изображения в библиотеке 

ІПІ 1еП_ир_согпег_Х ; // Границы области экрана, в которой 

ІПІ 1еП_ир__согпсг_Ѵ ; // будет нарисовано изображение 

ІПІ гі^Ьі_<Іочгп_согпег_Х ; 

ІПІ гівЫ~сІоюп2согпег_Ѵ ; 

ІПІ <іе1іХ_ж1ісІе_{і1е ; // Экранное соотношение изображения 

ІПІ (1е1іУ~ж1і(]е~Гі1е ; 
раЫіс: ~ ~ 

ж1(1^тепи_іІет(сЬаг *т_ж_пате,іпІ 1_и_Х,іпІ І_и_Ѵ, 

Гпі г_(ГХ4пІ г_«1_Ѵ) ; // создать пуюст графического меню 

ѵоій с1ігёсІ_Гі11_жёёк^а<Ійг ( Іопж ж_а<і<1г ) ; 

~ ” //Установить адрес начала графических 

// данных пункта меню в файле 

библиотеки 

ѵоісі (1гааг_тепи_і1ет( іпі ЬиГ^еге<1_ж1Ь ) ; // Нарисовать пункт меню 
ѴОІСІ тепіГ_ііет_[асііѵаІе() ; ~ // Выделить пункт меню 

// (подсветить или взять в рамку) 
ѵоЫ тепи_іІет_(ІеасІіѵаіе() ; // Убрать подсветку или рамку 

ѴОІСІ егаже_тепи_і1ет() ; // Удалить пункт меню с экрана 

ѴОІСІ жеі_тепи_ііет Ьогс1егж( іпі Іих , іпі Іиу , 

ІПІ ГСІХ , ІПІ гсіу') ; // Установить пределы области изображения 
// пункта меню на экране 
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Обратите внимание на то, что при разработке 
методов класса 8Ііс1е_тепи нам необходимо знать 
только спецификацию вызова методов класса (т.е. 
только секцию риЫіс спецификации класса). Теперь 
для прорисовки пункта в методе сігадѵ_тепи класса 
8ІісІе_тепи нам необходимо вместо 

(о(оху( «X і-го пункта меню» , «V і-го пункта меню» ) ; 
сриІ*( «строка і-го пункта меню» ) ; , 

как В случае текстового меню, писать 

(*іІеті[і]).<1гам_піепа_і(ет( 1іЬ_Ьап(і1е ) ; , 

где 1іЬ_Ьапс11е — указатель на открытый файл 
библиотеки, откуда нужно читать графические 
данные. 

Конкретный вид программы вывода графического 
меню (метод сіга^_тепи класса 8Ііс1е_тепи) может 
быть, например, таким: 

ѴОІСІ і1і(1е_тепи::(]гам_тепи( іп( Ьи{Геге<1_<1Ь ) 

}/ Вычислить все текущие углы слайдов по процедуре 
// і(ет_соог<]іпаІе«, затем отрисовать все слайды меню 

іпі іс ; // счетчик пунктов 

іпі І11Х , Іиу , тдх , гду ; 

Гог ( іс-0 ; іс « тах_і1ет ; іс + + ) 

}/ Вычисление координат углов всех пунктов (и их установка) 
іІет_соогс1іпаІеі( тах_іІет , іс , Діих , Аіиу , Агсіх , Агйу ) ; 

(*іІетс[іс])ле( тепи_і(еш_Ьог(1егі (1их,1иу»г(1х,гс)у) ; 

}; 

с1еагѵіевфогі() ; // порт вывода и іпри(_ЬиГГег устанавливаются для 

// меню или меню системы^в вызывающей программе 

Гог ( іс-0 ; іс « тах_і1ет ; іс++ ) 

// отрисовать все пункты 
(*і(ет«[іс]).с1гааг_тепа_і(ет( ЬиГГеге<1_с1Ь ) ; 

)^’ 

Метод с1гаАѵ__тепи_і1егп класса 8Іс1_тепи_йет выво- 
дит графический пункт меню на экран путем чтения и 
интерпретации структуры графического файла, выпол- 
няя при этом масштабные преобразования. Это до- 
вольно сложная программа, но пользоваться ей просто. 

Таким образом, мы подходим к еще одной замеча- 
тельной особенности объектно-ориентированных язы- 
ков. 00 языки позволяют разбить прикладную задачу 
на уровни программного обеспечения (подобно прин- 
ципу уровневого построения эталонной модели прог- 
раммного обеспечения взаимодействия открытых сис- 
тем). Каждый уровень имеет четко определенный ла- 
коничный интерфейс и набор услуг (методов), предос- 
тавляемых верхнему уровню. Используя механизм вир- 
туальных функций С++ можно организовать интер- 
фейс между уровнями так, что исходные тексты вер- 
хнего уровня не будут зависеть от структуры объектов 
нижнего уровня, с которыми они оперируют, В этом 
случае одна и та же программа позволяет оперировать 
с существенно различными данными. Пример из об- 
ласти организации интерфейса пользователя достаточ- 
но нагляден. Но тот же подход распространим и на 
любые задачи. Так, например, программа расчета по 
методу МКЭ может не зависеть от вида самих конеч- 
ных элементов; сетевая операционная система может 
работать без изменения с различными протоколами 
нижнего уровня и т.д. 


Перед нами открывается перспектива форма- 
лизации алгоритмических знаний человечества в 
различных прикладных областях на основе единых 
инженерных средств. Мы станем свидетелями создания 
огромных библиотек прикладных объектов с четко 
определенными интерфейсами, созданных в 
переносимой, не зависящей от оборудования форме. 

. Разбиение на уровни и спецификация уровней в 
прикладном программном обеспечении скорее всего 
станет следующим объектом стандартизации в ком- 
пьютерной науке. 

Особенностью современного этапа компьютеризации 
в нашей стране является то, что теперь с 
компьютером все чаще вынуждены взаимодействовать 
люди неподготовленные — бухгалтеры, конструкторы, 
технологи, рабочие и многие другие. Эти люди несут 
громадный обьем прикладных знаний. И применение 
ими новых методов компьютерной обработки 
информации должно дать огромный эффект. 

Неподготовленный пользователь должен работать с 
компьютером, оперируя привычными для него поняти- 
ями и образами. Этот принцип используется в разра- 
ботанном авторами пакете АиЩМЕМІІ, который пре- 
доставляет программисту развитые средства графичес- 
кого взаимодействия с пользователем. 

Опыт показывает, что применение объектно-ориен- 
тированных методов в разработке программного обес- 
печения дает следующие результаты: 

- повышается индивидуальная производительность 
труда программиста; 

- возрастают возможности проектирования (используя 
С-И-, программист вполне может разрабатывать прог- 
рамму объемом 25 000 строк и более). 

- увеличивается время начального этапа проектирова- 
ния (продумывание структуры и функций програм- 
мы); 

- существенно уменьшается время отладки программы; 

- на порядок уменьшается время разработки новых 
функций и внесения изменений в программы. Чем 
тщательнее проведено предварительное проектирова- 
ние, тем больше возможностей по внесению измене- 
ний в готовую разработку; 

- 00 программа лучше приспособлена для ее разра- 
ботки коллективом программистов; 

- существенно повышается надежность функциониро- 
вания программ. Логические ошибки практически 
полностью устраняются на стадии предварительного 
п роект и рова н ия ; 

- возрастают возможности по использованию в новых 
разработках частей работающих программ (с их ми- 
нимальными модификациями). 

Важным и продуктивным направлением исследова- 
ний может стать создание проблемно-ориентирован- 
ных систем автоматической генерации программ из 
библиотек типовых модулей, на основе объединения 
концепций С-н- и возможностей экспертных систем. 

Б.Ткаченко 
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КісНагё 8. АѴеіпег апё Ьеѵіз Ріпзоп, Іпігосіисііоп Іо 
ОЬ]ес1-Огіеп1е(і Рго^гаттіп^ апсі С++“, МА. Аёіззоп 
>Ѵез1еу. 1988 

Зіапіеу, Іірртап, Зігоизігир “Роіпіегз Іо Сіазз МетЬегз 
іп С++“, иЗЕНІХ С-н- Сопіегепсе, ОсІоЬег, 1988. 

В^агпе Зігоизігир “ТНе С++ Рго^гаттіп^ Ьап^иа^е**, 
Асісіізоп >Ѵез1еу, Яеасііп^, МА, 1986. 

Асііе СоІЬег^ апсі Оаѵісі ИоЬзоп “8МА1ХТАиС-80: ТЬе 
Іап^иа^е апсІ ііз ітріетепіаііоп**, Асісіізоп->Ѵез1еу, МА, 
1983. 

КаІрН іоНпзоп апсі Вгіап Рооіе **Оезі^піп^ ВеизаЫе 
С1аззез“, іоигпаі оі ОЬіесІ-бгіепІесі Рго^гаттіп^, 
іипе/іиіу 1988. 

ТигЬоС-и-1.0 Рго^гаттег'з СиісІе, Вогіапсі 
Іпіегпаііопаі, СА, ІІЗА. 


// Привсдеимая ммжс ярограмиа тестироаадась в ^>еде ТигЪо С-І-Ч- 1.0. 
// Методы, декларируемые в описании класса ниже фикции ѵів<1рор, 
// в данном примере не используются, но они иллк>стри|^ют то, 

// как, добавляя новые методы, можно сделать интерфейс меню 
// более гибким. 

// Соругі|Ы В.ТкасЬеяко,1990Д>віергоре(гоѵгіс сііу 

#с)еГіве МАХ.ѴАК.КиМВЕК 160 

#деПве СОС ОВОІНАКѴ СВЕЕМ 

#<1еПве ВК.ОВОІМАКУ В^АСК 

#(1еІіве СОЕ ЗЕЕЕСПОМ ѴН1ТЕ 

#(ІеСіве ВК ^ЕЕСТЮМ МАСЕМТА 


#деГіве СОЕ АЕАКМ ѴНІТЕ 

#<1еСіпе ВК_АЕАКМ КЕО 


#аеПве СОЕ АЕАКМ 8ЕЕ ВЕАСК 

#аеГіпе ВК_ЛЕАКМ_$ВЕ ЕІСНТСКАУ 


#іас1ис1с «теш А» 
#івс1и<1е «доеЛі» 
#іас1и(Іе «аІгіак.Ь* 

# іас1и<1е «соаіо.Ь» 
#іас1а<Іе «аі<ііо.Ь* 

# іасіасіе «еісИіЬА» 

// для ежіі 

# іасіасіе «таіЬ.Ь* 


# іасіасіе **кеуЬоагсЦі‘* 


// Константы класса МЕМУ.ѴЕКТ 


#с1еПае МАХ ГГЕМ АМОУМТ 
#с1еГіае МАХ"іТЕМ"іЛ^ІОТН 
#с1еГіае ВОКОЕК СОЕОК 
#с1еГіае РКАМЕ СОЕОК 
#с1еГіае ЗЕЕЕСТІОМ СОЕОК 
#аеІіае ВОКОЕК ВІ^ СОЕОК 
#с1е<іае РКАМЕ бК СОЕОК 
#с1еСіаеЗЕЕЕСТ!ОКГВК СОЕОК 


20 

80 

СОЕ ОКОІМАКУ 

СОЕ*ОКОІМАКУ 

СОЕ“ЗЕЕЕСТІОМ 

ВК ОКОІМАКУ 

ВК~ОКОІМАКУ 

ВК'ЗЕЕЕСТІОМ 


// Определеине класса МЕМО.ѴВКТ 
сіаае теаа ѵеП ~ 

( 

рпѵаіе: 

іаі ж : // Текущий левый вержиий угол меню 
іаі у ; 

іа( ргсасаІ_і(ет ; // Текущий (подсвеченный) пункт меню 

іаі аапіЬеГоІ_іІеаі ; // Текущее число пунктов меню 

іаі ж міс1іЬ~; ~ // - шаж ( аігіеа ( ііет а11 )) 

іаі (Гс}Ь_теаа_ксу ; // Выбирающая клавиша 

іаі а1оЬ“аісаа~ііеаі ; // Выбранный пункт меню 

сЬаг ііеш[МАЯ ГГЕМ АМОиМТНІ^^АХ 1ТЕМ >Я^ІОТН] ; // Пункты меню 
сЬаг •аѵе,агеа[(иАХ_ТТЕМ_АМОУМТ*1ІІАХ ГГЕМ_ѴІОТН)*2+101 ; 

// Область сожранемия экрана 

раЫіс: 


ѴОІСІ іаіі() ; // Инициализировать пустое меню 

ѴОІСІ ас1с1_ііепі( сЬаг *всчгііет ) ; // Добавить строку в меню 

ѴОІСІ с1гам_аіева() ; // Нарисовать меню с сожр. экрана (под ним). 

ѴОІСІ теай^сЬоісе() ; /У Выбирать пункты меню 

ѴОІСІ егааеЗвеввО ; // Удалить меню с всхчггаиовлеиие эішна 

ѴОІСІ ееі^піёва^жуі іаі іаж, іаі іау ) ; // Установить левый вержний угол 
іаі {еі^1оЬ_тева_кеу() ; /У Получить клавишу выбора строки меню 
іаі кеі_(1оЬ~івеаа~ііеів() ; // Получить номер выбранной стрсжи 


// Служебные функции сожраиеиия старого экрана 
ѴОІСІ міасІам( іві ж1 , іаі у1 , іаі ж2 , іаі уі ) ; 

ѴОІСІ юіас1рор( іаі ж1 , іаі у1 , іаі ж2 , іаі у2 ) ; 

іаі (еі_ж_ѵгіс1ік0 ; // Функции доступа к скрытым данным класса 

іаі аеіЗаиніЬег^оС^ііетО ; 

ѵоіо •ёі_ііеів( ІВІ Гіет_ватЬег , сЬаг *веягііет ) ; // Изменить 

” ” // существующий пункт 

ѴОІСІ •еі_ргеаеві_ііст ( іві ііеті ) ; // Принудительно установить номер 

” /У текущего пункта меню 

ѴОІСІ кісІе_ііеяи_сагаог() ; // Убрать подсветку текущего пункта 

ѴОІСІ сІгаі^ііетГ сагаог() ; // Снова подсветить текущий пункт 

ѴОІСІ сіеаг'тева'^) ; // Прописать все пункты пробелами 


// Функции используются членами класса МЕМІІ_ѴЕКТ 
ѴОІСІ сігам Ьож( 

іаі " іур , 

/* 0- сІоаЫе Иве */ 

/* 3 - «расе сЬагасіег* овіу */ 
іві СОІ , /* СОІОГ о{ іЬе Ьож Ьогсіег */ 

іаі соІЬк , /* СОІОГ оС іЬе Ьож Ьогсіег */ 
іві у1 , /• ж1 « ж2 ; у1 « у2 •/ 

іві ж1 , 

іві у2 , 

іві ж2 

< ’ 

ІВІ і ; 

іаі СІЖ , с^ ; 

скаг *гі{Ьі аррег , *Ьог Ііа , *1е1і_аррег , *ѵегі_1іа , 
*гі|,Ъі ЬсЯіот , *Гёіі Ьоііот ; ~ 

тіісЬ ( іур ) “ 

саае 0: ( 

Іе1і_аррег - “ж“; 
гі^Ьі_пррег -“ы“; 


ѵегі_1іа -“ь“; 
Ьог_1іа - “щ“; 
гі(Ьі_Ьоііот -**ь“; 

1е!і_Ьоііот -“ф“; 

} ; Ьгеак ; 
сааеЗ: ( 

1еСі_аррег - “ 
гіжй аррег 
ѵегі Тіа 
ЬогЗіа 
гі|М_Ьоііот 
Іеіі Ьоііот 
■> ; Ьгеак ; 

іежісоіог(соі) ; 
іежіЬасквгоавсІ(соІЬк) ; 


СІЖ - ж2 - ж1 ; 
сіу - у2 - у1 : 

Коіожѵ(жіогі) ; 
сраі«(1еП_аррег) ; 

ІОГ ( 1-1 7 і«- СІЖ-1 ; І + + ) сраи(Ьог_1ів) ; 
сраіс(гіжЬі аррег) ; 

Іог ( 1-1 ; Г*- с1у-1 ; і + + ) 

воіожу(ж2,уІЧ-і) ; 
сраі«(ѵегІ_1ів) ; 

Коіожѵ(ж1,у1Ч-і) ; 
сраіс(ѵегі_1іа) ; 

80 іожу(ж 1 ,у 2 ) ; 
сраі«(1еСі_Ьоііот) ; 

Іог ( і-іТі*“ <1*-1 ; І + + ) сраі«(Ьог_1іа) ; 
сраі«(гісЬі_ЬоСіот) ; ~ 


іві івс_ро«(іві *саг ж , іві *саг_у , іві *ж1 , іаі *ж2 , іві *у2 ) 

/* Сервисная функция для процедур ШІМОЗѴ^ апсі \ѴІМОРОР •/ 

іві івс_ро«_уаг ; 
іас^рос ѵаг - 1 ; 

(•саг жТ++ ; 

ІГ ( (•Ьаг_ж) » Сж2) ) 

(•саг_у) + + ; 

(•саг_я) - (•жі) - 1 ; 

ІГ ( (*саг__у) * (*у2) ) іас_ро«_ѵаг - 0 ; 
геіага( іпс^ро«_ѵаг ) ; 


/* Процедура временного сожранения окна */ 

ѴОІСІ тепа ѵегі:жівс1ем( іаі ж1 , 
іві у1 ," 
іаі ж2 , 
іві у2 

#с1сГіве ЗсгеевВаГГег 0хЬ800 /• $Ь000 — монохромный режим */ 

іаі і, свг_ж , саг_у ; 
свг_ж"^ х1 -2 ; 
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сиг_^ - у1 -1 ; 

ѵЬіІе ( іпс_ро*( Дсиг_х , Дсаг_у , Дхі , Ах2 , Ау2 ) ) 

тоѵе<ии($сгеепВиСГег,(сог х+сиг_у*80)*24^Р 8ЕО(Апѵе агежГіІ), 

“РР ОРР(Амѵе_«Геа[і])^) ; 

і - і + 2 ; 

); 

геіиш ; 

) 

/* Процедура восстановления окна */ 
ѵоіЛ шево ѵегІ:пніп<Ір<ф( 

{ві х1 , 

іві у1 , 

ів( х2 , 

ІВІ у2 

# (ІеПве ЗсгеевВиПег 0хЬ800 /* $Ь000 — монохромный режим */ 

{ 

ІВІ I, свг_х , сиг_у ; 
саг X - х1 -2 ; 

мЬіІе ( івс_ро*( Асиг_х , Асиг_у , Ахі , Ах2 , Ау2 ) ) 

вісте(1аІа(РР_$ВС(Аааѵе_агеа[і])Д’’Р ОРР(Асаѵе агеаГіІ) 
^гёевВиііег,(сиг х+сиг_у^80)*2Д) ; 

і - і + 2 ; 

}; 

> 

// Методы класса МЕНУ.ѴЕКТ 
ІВІ в»епи_уеіі::*еІ_х_агі(ЛЬ“’() 

геІигв(х_агі(]іЬ) ; 


ІВІ тева_теП::(еІ_вавіЬег_оМіеві() 

геІагв(вавіЬег оС ііет) ; 

> 

ІВІ віеви_ѵегІ::{еІ_(1оЬ_віева_кеу() 

геІигв((1оЬ_віева_кеу) ; 

> 

ІВІ віева_тегІ::хеІ_х1оЬ_віева_іІет() 

геІигв((1оЬ_вкева_ііеві) ; 


ѴОІСІ віева_уегІ::івіІ() 

// инициализация вертикального меню 

X - О ; 

У - 0; 

витЬег_^оМіет - 0 ; 
ргееевіііеш - 0 ; 

X місІІіГ - о ; 

(ГоЬ_тева_кеу - 0x20 ; 
{ІоЬ'тевиЗіет - 0 ; 


ѴОІСІ віева_ѵеіі:х1еаг_віеви() 

^ ІВІ і , і ; 

Гог С і-1 ; і«-виюЬег_оГ_іІет ; і++ ) 

^ іІешГіѴО] - 0x00 ; 

Гог 0-1 ; і«- х_ѵгіс1іЬ ; ^++ ) сігсаІ(ііет[і],** “) ; 


ѴОІСІ тева_уегІ::віеви_сЬоісе() 
// выбор в~вертикалыіом меню 

^іві і ; 

ІВІ } ; 

ІВІ аеег^кеу ; 

ІВІ ргеѵТоиі_іІет ; 

иаег_кеу - 0x20 ; 


ѵЬіІе ( 

І иеег кеу I- ЕА8С Евіег ) АА 
и«ег~кеу 1- ЕА8СІ^еГI ) АА 

иеег'кеу I- ЕЛбС^Кі^Ы ) А А 

иаег”кеу !- ВА$С~Еас ) 


оаег^кеу - і_геас1кеу() ; 
ргеѵТои>_іІет - рге«еві_іІеві ; 

пгіісЬ ( иіег_кеу ) 

сам ЕА$С_Ноте 

! )ге«еві ііет - 0 ; 
; Ьгеаіс ; 

I : 

” { 


} ; Ьгеак ; 

ЕА$С_Ева 

ргеееві ііет - витЬег_оГ_іІет - 1 ; 

} ; Ьгеаіс ; 

ЕА5С_Ур 

ІГ ( рге«еаІ_іІет - - 0 ) 
ргееевМіет - витЬег_оГ_іІет ; 
іГ ( ргеаевМіет * 0 ) ” 
ргеаеві ііет — ргеаеві ііет - 1 ; 

> ; Ьгеак ; 

ЕА8С Оомв 

“ ( 

ргеаевМіет - рге«евІ_ііет + 1 ; 
іГ ( ргесевМіет *- витЬег_оГ_іІет ) 
ргеееві іІет-0 ; ” ” 

} ; Ьгеак ; 

ЕА5С_Р*0р : 

} ; Ьгеак ; 

ЕА8С Кі^Ьі : 

{ 


I ; Ьгеак ; 

сасе ЕА8С Р^бв 
{ 

} ; Ьгеак ; 

} ; // «шіІсЬ 


ІехІсо1ог(РКАМЕ_СОШЕ) ; 
8оіоху(х+1^+1+ргеѵіоиа ііет) ; 
срцІ*(ііет[ргеѵіоис ііет]) ; 
^еx^соIог(5Е^ЕСТIбN_СО^ОК) ; 
^оІоху(х+1,у+1+рге*еЛ ііет) ; 
сриІс(іІет[рге«евМіет]) ; 


8ІсіЬ_теви_кеу-и»ег_кеу ; 

^1оЬ~теви_іІет-ргесепІ_іІет ; 

) ; // шЬіІе 

} // метод теви_сЬоісе 

ѴОІСІ тева_ѵеП::^гаѵг_тепи() // с сохранением предыдущего экрана 

ІВІ і , I , у2 , х2 ; 

у2- у -I- витЬег оГ ііет Ч- 1 ; 
х2- X + х_міс1іЬ”+ Т ; 

(*ІЬІ«).ШІ2ІСІСѴГ( 



КОЕК СОЬОК) ; 

IеxIЬаск{гоивс^(ВОК.^ЕК_Вк_СО^ОК) ; 


сігам Ьох( о, 

“ ВОКОЕК СОЬОК, 
ВОКОЕК'ВК СОЬОК, 
У. 



ІехІсо1ог(РКАМЕ СОЬОК) ; 
IеxIЬасквгоивс1(РКАМЕ_ВК_СО^ОК) ; 

Гог ( і-0 ; і«-витЬег_оГ_іІёт - 1 ; і + + ) 

ІГ ( і - - ргеееві ііет ) 

{ ІехІсо1ог(РКАМЕ СОЬОК) ; 

^еxIЬаскв^оивс](РГ^^.МЕ_ВК_СО^ОК) ; 


80іоху(х+1ог+1+і) ; 

Гог ( ]-х+1 ; )«-х+х_ѵгісЛЬ ; )++ ) 

§оЮху^х+1,у +1+І) ; 
сриіі( іІет(і] ) ; 

ІехІсо1ог(РКАМЕ СОЬОК) ; 
IеxIЬаск{гоивс](РКАМЕ_Вк_СО^ОК) ; 


ѴОІСІ теви_ѵегі:леІ_теви_ху( іві івх , іві іву ) 
// установить левый і^хний угол 

X - івх ; 
у - іву ; 


ѴОІСІ тева_уеіі:хс1с1_і1ет( сЬаг *вемііет ) 

•Ігсру(іІет[витЬег оГ_іІет],веогіІет) ; 

ІГ ( х_міс1іЬ « (Ігіев^веѵііет) ) х_місИЬ - •Ігіев(веѵііет) ; 
витЬёг_оГ_іІет - витЬег_оГ_іІет + 1 ; 
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> 

ѴОІСІ тепи_ѵегІ:ж(_і(ет( ІШ іІеіп_питЬег , сЬаг ^пеѵііет ) 
// Изменить значение существующей строки меню 

ІГ ( ііет питЬег « питЬег оМіеш ) 

{ *Ігсру(7(еііі[іІет_витЬег]7пеѵі(ет) ; 

еім 

•Ігсру(іІет[витЬег_оМ(ет],пеігі(ет) ; 

ѵоі(1 тепи_уегІ::ега*е_тепи() 

// без восстановления предыдущего экрана 

іп( і , ^ , у2 , ж2 , у1 , х1 ; 


у2 - у+питЬег_оМіет+1 ; 
х2 - х+х мі<ІСЬ'+іТ 
у1 - У ; ~ 

х1 - X ; 


*іЬіа).міп()^р( 


); 


х2, 

У2 


ѵоі(] тепи_уегІ:жІ_ргеаеп(_і(ет ( ів( ііеті ) 
ргеаепІ_і(ет-йеш1 ; 

и ( ргеаепі ііеш » питЬег оі іСеш-1 ) ргесепМіет - питЬег_оГ іІет-1 ; 

) - 

ѴОІСІ тепи ѵегІ::с1гаіг_і(ета сигаог() 

{ 

іпс і , і ; 

і - ргеаепі іІет ; 

(ех1со1ог($ЕЬЕСЛГІОН СОЕОК) ; 
ІехіЬасквгоипс1($ЕЕЕСТібН_ВК_СОЕОК) ; 

|оІоху(х+1ог+1+і) ; ” ~ 

іог ( і-х+1 ; і«-х+х_місИЬ ; і + + ) 

*оіоху(іог+1+і) ; 

^ сриІіС** •*) ; 

8С)Іоху(х+1^+1+і) ; 
сриІа( і1ет[і] ) ; 


ѴОІСІ тепа_ѵег(::Ьіс1е ііета сигаог() 

{ 

іп( і , і ; 
і - ргеаепі ііет ; 

Іех1со1ог(РКАМЕ СОЕОК) ; 
ІехіЬасккгоипс1(ЕКАМЕ_Вк_СОЕОК) ; 
іоіоху(х+1,у +1+І) ; 

ІОГ ( )-х+1 ; і«- х+х_ігісІіЬ ; і + + ) 

^о1оху(х+1ог+1+і) ; 
сриІа( іІет[і] ) ; 


таіп() 

тепи_ѵеіі аЬссИ , аЬссІ2 , аЬссІЗ ; 


аЬсс11.іпіІ() ; 

аЬсс11лс]с1_іІеті 
аЬсс11лсІс1_іІеті 
аЬссІ1дсІс]~іІеті 
аЬссІ 1 л с1с1_іІет I 
аЬссІ1лс]с1_іІеті 
аЬссИлсІсіЗіеті 
аЬссИлсІсіЗіепіі, 
аЬсс11леІ_тепи^ху(1,1) ; 
аЬсс1Ес1гаѴг_тепи() ; 
аЬсс1Етепй^сЬоісе() ; 
аЬсс1Еегаае~тепи() ; 


“ЗАГРУЗИТЬ-) ; 
“НОВЫЙ ФАЙЛ-) ; 
-СОХРАНИТЬ-) ; 
-ЗАПИСАТЬ В .„“) 
-КАТАЛОГ-) ; 
-ВЫХОД В 005' 
ПОКИНУТЬ 


05-) ; 

- АН Х-) ; 


аЬссІ2.іпіІ() ; 


аЬсс12лс1с1 іІет(-КОНТРОЛЬ СКОБОК-) ; 

аЬсс12лс]с1~іІет(-КОНТРОЛЬ СИНТАКСИСА-) ; 

аЬсс12ле1_тепа_ху(20Д) ; 

аЬссІ2.с1гайг_тепи() ; 

аЬсс12.тепй^сЬоісе() ; 

аЬссІ2.егаае1пепи() ; 

аЬс^.іпіІ() ; 

аЬссІЗлсІсІ іІет(-СПИСОК СИНТАКСИЧЕСКИХ ОШИБОК-) ; 
аЬссІЗласі'іІетГ-ИСПОЛЬЗОВАННЫЕ ЛИТЕРАЛЫ-) ; 
аЬссІЗлсІсІ іІетГИСПОЛЬЗОВАННЫЕ КОНСТАНТЬІ-) ; 
аЬссОлс]сі''іІет(-ИСПОЛЬЗОВАННЫЕ СТАНДАРТНЫЕ ФУНКЦИИ-) ; 


аЬссіЗлс1с1^Iет(-ФУНКЦИИ ПОЛЬЗОВАТЕЛЯ-) ; ' . 

аЬсс13леІ_тепи_ху(43,1) ; 

аЬсс13.с1гаѵг_тепи() ; 

аЬсс13.тевй^сЬоісе() ; 

аЬссІЗ.егаае^тсоиО ; 

) // конец таіп 

ІЫСЕЦОЕ - файл КЕУВОАКО.Н 


#сІеСіпе 

ЕА$С Р1 

1059 

# сІеСіпе 

ЕА8С"Р2 

1060 

#с1еГіпе 

ЕА8С“РЗ 

1061 

#сІе(іпе 

ЕЛ8С Р4 

1062 

#с1еГіпе 

ЕА8С“Р5 

1063 

#с1еГіпе 

ЕА8С Р6 

1064 

#с1еІіпе 

ЕА5С Р7 

1065 

# сІеСіпе 

ЕА8С Р8 

1066 

#с1еГіпе 

ЕА5С“Р9 

1067 

#сіе{іпе 

ЕАХС^РЮ 

1068 

# сІеГіпе 

ЕА5С 5ЬІГІ Р1 

1084 

#сІеПпе 

ЕА5С 8ЬІГІ Р2 

1085 

# СІеГіпе 

ЕА8С~8ЬІГІ РЗ 

1086 

#с1еПпе 

ЕА8С 8ЬІГІ Р4 

1087 

# СІеГіпе 

ЕА8С 8ЬігГР5 

1088 

# СІеГіпе 

ЕА8С"8ЬІГІ Рб 

1089 

# СІеГіпе 

ЕА8С“8ЬІГІ Р7 

1090 

# СІеГіпе 

ЕА8С 8ЬІГІ Р8 

1091 

# СІеГіпе 

ЕА8С 8ЬІГІ Р9 

1092 

# СІеГіпе 

ЕА8СІ8ЬігГР10 

1093 

# СІеГіпе 

ЕА8С Сігі Р1 

1094 

# СІеГіпе 

ЕА8С Сігі Р2 

1095 

# СІеГіпе 

ЕА8С”Сіг1 РЗ 

1096 

# СІеГіпе 

ЕА8С”СігГР4 

1097 

# СІеГіпе 

ЕА8С”СігГР5 

1098 

# СІеГіпе 

ЕА8С"*Сіг1 Р6 

1099 

# СІеГіпе 

ЕА8С“аг1 Р7 

1100 

# СІеГіпе 

ЕА8С"СігІ Р8 

1101 

# СІеГіпе 

ЕА8С Сігі Р9 

1102 

# СІеГіпе 

ЕА8С_Сіг1_Р10 

1103 

# СІеГіпе 

ЕА8С АН Р1 

1104 

# СІеГіпе 

ЕА8С АіГР2 

1105 

# СІеГіпе 

ЕА8С АН РЗ 

1106 

# СІеГіпе 

ЕА8С АН Р4 

1107 

# СІеГіпе 

ЕА8С”АіГР5 

1108 

# СІеГіпе 

ЕА8С АіГРб 

1109 

# СІеГіпе 

ЕА8С АіГР7 

1110 

# СІеГіпе 

ЕА8С АН Р8 

1111 

# СІеГіпе 

ЕА8С"АіГР9 

1112 

# СІеГіпе 

ЕА8С_АН“Р10 

1113 

# СІеГіпе 

ЕА8С Ноте 

1071 

# СІеГіпе 

ЕА8С ЕеП 

1075 

# СІеГіпе 

ЕА8С ЕпсІ 

1079 

# СІеГіпе 

ЕА8С_Цр 

1072 

# СІеГіпе 

ЕЛ8С Ооѵп 

1080 

# СІеГіпе 

ЕА8С Р^Цр 

1073 

# СІеГіпе 

ЕА8С”КівЫ 

1077 

# СІеГіпе 

ЕА8С_Р*Ьп 

1081 

# СІеГіпе 

ЕА8С СІГІ Ноте 

1119 

# СІеГіпе 

ЕА8С“СігГЕеГі 

1115 

# СІеГіпе 

ЕА8С Сігі ЕпсІ 

1117 

# СІеГіпе 

ЕА8С'‘Сіг1 Р^Цр 
ЕА8С"СігГКівЫ 
ЕА8 С_СігГР*Ьп 

1132 

# СІеГіпе 

1116 

# СІеГіпе 

1118 

# СІеГіпе 

ЕЛ8С Іпі 

1082 

# СІеГіпе 

ЕА8С”Ое1 

1083 

# СІеГіпе 

ЕА8С“8ЬіГі ТаЬ 

1015 

# СІеГіпе 

ЕА8С"СігІ Тгііс 

1114 

# СІеГіпе 

ЕА8С~СігІ_Вгеак 

1000 

# СІеГіпе 

ЕА8С Епіег 

13 

# СІеГіпе 

ЕА8С Еас 

27 

# СІеГіпе 

ЕА8С_8расе 

32 

# СІеГіпе 

ЕЛ8С АН А 

1030 

# СІеГіпе 

ЕА8С АН В 

1048 

# СІеГіпе 

ЕА8С АН С 

1046 

# СІеГіпе 

ЕА8С АН О 

1032 

# СІеГіпе 

ЕА8С АіГЕ 

1018 

# СІеГіпе 

ЕА8С”АН Р 

1033 

# СІеГіпе 

ЕА8С АіГО 

1034 

# СІеГіпе 

ЕА8С АН Н 

1035 

# СІеГіпе 

ЕА8С АіГі 

1023 

# СІеГіпе 

ЕА8С"АіГі 

1036 

# СІеГіпе 

ЕА8С АН К 

1037 

# СІеГіпе 

ЕА8С АіГЕ 

1038 

# СІеГіпе 

ЕА8С_АіГМ 

1050 

# СІеГіпе 

ЕА8С АН N 

1049 

# СІеГіпе 

ЕА8С“АіГО 

1024 

# СІеГіпе 

ЕА8С АН Р 

1025 

# СІеГіпе 

ЕА8С АН О 

1016 

# СІеГіпе 

ЕА8С АН К 

1019 

# СІеГіпе 

ЕА8С"АН 8 

1031 

# СІеГіпе 

ЕА8С АН Т 

1020 

# СІеГіпе 

ЕА8С"АН Ц 

1022 
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59 


^Леііпе 

ВА$С АН V 


1047 

#<ІеГіае 

ЕАЗС’АН'^Ѵ 


1017 

#«1е{іве 

ЕА5С"АН“>С 


1045 

#беСіве 

ЕА8С’АН“Ѵ 


1021 

#«ІеГіве 

ВА8СІАІГ2 


1044 

#«ІеГіве 

ВА8С СІГІ А 

01 


#беПве 

ЕАХСГСігГВ 

02 


#<1еПве 

ВА8С“агГС 

ОЗ 


#беПве 

ЕА8С” СігГО 

04 


#<ІеПве 

ЕАХС'СігГВ 

05 


#беСіве 

ВА5С“СігГР 

06 


#<ІеСіае 

ЕАХС'ОгГО 

07 


#<іеГіве 

ВА5С“СігГН 

08 


#<іеПве 

ВА5СГ СігГі 

09 


#беСіве 

ВА8С”агП 

10 


#беПое 

ЕА8С“СігГК 

11 


#«ІеПве 

ЕА8С“СігГЬ 

12 


#<ІеПве 

ВА8С"СігГМ 

13 


#(ІеПое 

ЕА$С СІГІ N 

14 


#беГівс 

ВА8С“СігГО 

15 


#<ІеПое 

ВА8С"СігГР 

16 


#беІіве 

ЕА8С“ СігГо 

17 


#беПве 

ЕА8С“агГК 

18 


#<ІеПве 

ВА8С“СігГ8 

19 


#беПае 

ЕА8С*"агі"Т 

20 


# беПве 

ЕА8С"СігГи 

21 


#<іеСіае 

ЕА8С“СігіЛ^ 

22 


#«ІеГіае 

ЕА8С"агГѴ 

23 


#беПве 

ВА8С“СігГХ 

24 


#беІіве 

ЕА8С"СігГѴ 

25 


#беІіве 

ВАХСІСігГІ 

26 


#беСіве 

ВА5С АН 1 


1120 

# беПве 

ВА5С"АіГ2 


1121 

#беПве 

ВАбС'АіГЗ 


1122 

#<1еПве 

ВА8С“АіГ4 


1123 

#(ІеПве 

ЕА8С“АН“5 


1124 

#(1еГіое 

ЕА8С“ АіГб 


1125 

#беСіве 

ВА8С"АіГ7 


1126 

#беГіве 

ВА8С"АіГв 


1127 

#беПве 

ВА8С" АіГ9 


1128 

#беІіве 

ЕА8С"АіГ0 


1129 

#(ІеСіве 

ВА5С АН Мівва 

1130 

#беііве 

ВА$С~АіГВяиа1 

1131 

іві і_геа<1кеу0 




сЬаг ш2 ; 

іаі • ; 

«ап(ве<1 сЬаг а1 ; 

* ** О ! // еслм нажата необрабатываемая управляющая клавиша 

// то возвращается иола 

•I - і«сЬО : 

м ( «11- о ) 

* геінгв(аі) ; /• АЗСІІ-код •/ 


•Г (а1 -- 0) 

^ а2 - (е(сЬ() ; 

аміІсЬ ( а2 ) /* расширенный А$СІІ-код */ 


саае 

59 

а 

_ 

1059 ; 

/• 

Р1 

•/ 


Ьгеак ; 

свае 

60 

а 

> 

1060 ; 

/• 

Р2 

•/ 


Ьгеак ; 

саае 

61 

а 


1061 ; 

/• 

РЗ 

•/ 


Ьгеак ; 

свае 

62 

а 


1062 

/• 

Р4 

•/ 


Ьгеак ; 

саае 

63 

а 


1063 ; 

/• 

Р5 

V 


Ьгеак ; 

саае 

64 

а 


1064 ; 

/• 

Р6 

•/ 


Ьгеак ; 

свае 

65 

а 

— 

1065 

/• 

Р7 

•/ 


Ьгеак ; 

саае 

66 

а 

— 

1066 

/• 

Р8 

•/ 


Ьгеак ; 

свае 

67 

а 

- 

1067 

/• 

Р9 

•/ 


Ьгеак ; 

саае 

68 

а 

- 

1068 

/• 

РІО 

V 


Ьгеак ; 

саае 

84 

а 


1084 

/• 

5ЬШ 

Р1 

V 

Ьгеак 

свае 

85 

: а 

- 

1085 

/• 

$ЬіІІ 

”Р2 

•/ 

Ьгеак 

саае 

86 

: а 


1086 

/• 

$ЬІГІ 

■рз 

V 

Ьгеак 

свае 

87 

: а 

» 

1087 

/• 

$ЬіП 

"Р4 

•/ 

Ьгеак 

саае 

88 

; а 


1088 

/• 

$ЬіП 

“Р5 

•/ 

Ьгеак 

саае 

89 

; а 

■> 

1089 

Л 

$ЬіП Р6 

•7 

Ьгеак 

саае 

90 

; а 


1090 

Л 

5ЬІІІІ?7 

•7 

Ьгеак 

саае 

91 

; а 

« 

1091 

/• 

$ЬіІІ>8 

•7 

Ьгеак 

свае 

92 

; а 


1092 

/• 


Р9 

•/ 

Ьгеак 

саае 

93 

: а 

■ 

1093 

Л 

$ЬіСІ>10 

•/ 

Ьгеак 

саае 

94 : 

: а 


1094 ; 

/• 

СІГІ 

Р1 

V 

Ьгеак ; 

саае 

95 ; 

; а 

- 

1095 : 

/• 

ОгГ 

Р2 

V 

Ьгеак 


сам 

96 



1096 

/• 

СІГІ РЗ 

V 

Ьгеак ; 

сам 

97 


— 

1097 

/• 

СІГІ Р4 

•/ 

Ьгеак ; 

сам 

98 


— 

1098 

/• 

СІГІ Р5 

•/ 

Ьгеак 

сам 

99 


- 

1099 

/• 

СІГІ Р6 

V 

Ьгеак ; 

сам 

100 


— 

1100 

/• 

ОгІ Р7 

V 

Ьгеак 

сам 

101 


-і 

1101 

/• 

СІГІ Р8 

•/ 

Ьгеак ; 

сам 

102 


— 

1102 

/• 

СІГІ Р9 

V 

Ьгеак 

сам 

103 



1103 

/• 

СігГРЮ 

V 

Ьгеак 

сам 

104 



1104 

/• 

АН Р1 

V 

Ьгеак ; 

сам 

105 


- 

1105 

/• 

АН Р2 

V 

Ьгеак 

сам 

106 


— 

1106 

/• 

АН РЗ 

V 

Ьгеак 

сам 

107 


— 

1107 

/• 

АіГР4 

•/ 

Ьгеак 

сам 

108 


— 

1108 

/• 

АН Р5 

V 

Ьгеак 

сам 

109 


— 

1109 

/• 

АН Р6 

V 

Ьгеак 

сам 

110 


— 

1110 

/• 

АН Р7 

•/ 

Ьгеак ; 

сам 

111 


— 

1111 

/• 

АН“Р8 

•/ 

Ьгеак ; 

сам 

112 


— 

1112 

/• 

АіГР9 

V 

Ьгеак ; 

сам 

113 



1113 

/• 

АН_Р10 

•/ 

Ьгеак 

сам 

71 



1071 

/• 

Ноте • 

/ 

Ьгеак 

сам 

75 


— 

1075 

: /• 

Ьеіі •/ 


Ьгеак ; 

сам 

79 


— 

1079 

/• 

Епб •/ 

Ьгеак ; 

сам 

72 


- 

1072 

; /• 

Ѵр •/ 


Ьгеак ; 

сам 

80 


- 

1080 

/• 

Ооагв • 

/ 

Ьгеак 

сам 

73 



1073 

/• 


/ 

Ьгеак 

сам 

77 


— 

1077 

: /• 

КіеЫ 

} 

Ьгеак ; 

сам 

81 


- 

1081 

/• 

Р*бв • 

1 

Ьгеак 


сам 

119 : а - 1119 ; /• СігІ Ноте 

V 

Ьгеак ; 

сам 

115 : а - 1115 ; /• СігІ ^е^^ 

V 

Ьгеак ; 

сам 

117 : а - 1117 ; /• СігГВвб 

7 

Ьгеак ; 

сам 

132 : а - 1132 ; /• СігГРаНр 

7 

Ьгеак ; 

сам 

116 : а - 1116 ; /• СігІ ВіаЫ 

V 

Ьгеак ; 

сам 

118 : а - 1118 ; /* СігІ_Р*Ьп 

V 

Ьгеак ; 

сам 

82 : а - 1082 ; /• Іп* •/ 


Ьгеак ; 

сам 

83 : а - 1083 ; /* ОеІ Ѵ 


Ьгеак ; 

сам 

15 : а - 1015 ; 7* 5ЬіСі ТаЬ 

7 

Ьгеак ; 

сам 

114 : а - 1114 ; /• СігІ ^Пм 

V 

Ьгеак ; 

сам 

0 : а - 1000 ; /• Сіг1^>геак 

•/ 

Ьгеак ; 

сам 

30 : а - ВА5С АН А ; 


Ьгеак ; 

сам 

48 : а - ЕАЗС" АН В ; 


Ьгеак ; 

сам 

46 : а - ВА8С“АіГС ; 


Ьгеак ; 

сам 

32 : а - ЕА8С~АН О ; 


Ьгеак ; 

сам 

18 : а - ЕА5С”АіГЕ ; 


Ьгеак ; 

сам 

33 : а - ЕА5С АіГР ; 


Ьгеак ; 

сам 

34 : а - ЕА5С АіГО ; 


Ьгеак ; 

сам 

35 : а - ЕА8С АН Н ; 


Ьгеак ; 

сам 

23 : а - ЕА8С АН I ; 


Ьгеак ; 

сам 

36 : а - ЕА8С АіГі ; 


Ьгеак ; 

сам 

37 : а - ЕА8С"АіГК ; 


Ьгеак ; 

сам 

38 : а - ЕА8С“АIГ^ ; 


Ьгеак ; 

сам 

50 : а - ЕА8С_АН_М ; 


Ьгеак ; 

сам 

49 : а - ЕА8С АН N ; 


Ьгеак ; 

сам 

24 : а - ЕА8С" АН О ; 


Ьгеак ; 

сам 

25 : а - ЕА8С АіГР ; 


Ьгеак ; 

сам 

16 : а - ЕА8С АН О ; 


Ьгеак ; 

сам 

19 : а - ЕА8С АН В ; 


Ьгеак ; 

сам 

31 : а - ЕА8С АН 8 ; 


Ьгеак ; 

сам 

20 : а - ЕА8С“ АН Т ; 


Ьгеак ; 

сам 

22 : а - ЕА8С АіГН ; 


Ьгеак ; 

сам 

47 : а - ЕА8С АН V ; 


Ьгеак ; 

сам 

17 : а - ЕА8С АН ѴѴ ; 


Ьгеак ; 

сам 

45 : а - ЕА8С" АіГХ ; 


Ьгеак ; 

сам 

21 : а - ЕА8С АН У ; 


Ьгеак ; 

сам 

44 : а - ЕА8С“А11_2 ; 


Ьгеак ; 

сам 

120 : а - ЕА8С АН 1 ; 


Ьгеак ; 

сам 

121 : а - ЕА8С"АН 2 


Ьгеак ; 

сам 

122 : а - ЕА8С" АіГ 3 ; 


Ьгеак ; 

сам 

123 : а - ЕА8С АіГ4 ; 


Ьгеак ; 

сам 

124 : а - ЕА8С“АіГ5 ; 


Ьгеак ; 

сам 

125 : а - ЕА8С" АіГб ; 


Ьгеак ; 

сам 

126 : а - ЕА8С‘’АН 7 ; 


Ьгеак ; 

сам 

127 : а - ЕА8С АН 8 ; 


Ьгеак ; 

сам 

128 : а - ЕА8С АН 9 ; 


Ьгеак ; 

сам 

129 : а - ЕА8С'’АіГ0 ; 


Ьгеак ; 

сам 

130 : а - ЕА8С“АіГМівиі 


Ьгеак 

сам 

131 : а - ЕА8С АН Еяиаі 

; 

Ьгеак 


) ; /• пгіІсЬ а2 •/ 


> ; /• V 

ге(игв(а) ; 

) 
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МАТЕМАТИЧЕСКИЕ ОСНОВЫ ЯЗЫКА ПРОЛОГ 



В основе языка логического 
программирования Пролог лежит логика 
предикатов первого порядка, точнее 
ограниченное подмножество логики 
предикатов, основанное на хорновских 
дизъюнктах [1 ] . Прежде чем 
рассмотреть логику предикатов, 
напомним некоторые положения логики 
высказываний (алгебры логики). 


Математические основы 

языка Пролог 


1. Логика высказываний 

Логика высказываний — это раздел математической 
логики, изучающий высказывания, рассматриваемые 
со стороны их логических значений (истинности или 
ложности) и логических операций над ними. Алгебра 
логики возникла в середине 19 века в трудах Дж. Буля. 

Создание алгебры логики представляло собой по- 
пытку решать традиционные логические задачи алгеб- 
раическими методами. Основным предметом алгебры 
логики стали высказывания и логические операции 
над ними. 

Высказывание — это повествовательное предложе- 
ние, рассматриваемое вместе с его содержанием 
(смыслом) как истинное или ложное. Истину и ложь 
называют истинностными значениями высказываний. 
Иначе говоря, под высказываниями понимаются пред- 
ложения, относительно которых имеет смысл утверж- 
дать, истинны они или ложны. 

Примеры высказываний: 

Следующие высказывания истинны: 

1 ) Сегодня на улице тепло. 

2) После окончания института студент получит дип- 
лом инженера. 

Следующие высказывания ложны: 

1) Диплом инженера студентам выдают на втором 
курсе. 

2) Сегодня будет солнечное затмение. 


Для обозначения истинности вводится символ “И“, 
а для обозначения ложности — символ “Л“. Вместо 
этих символов часто употребляются числа 1 и 0 . 

С помощью пяти логических связок “и“, “или“, 
“эквивалентно**, “если ..., то ...** и частицы “не** из 
уже заданных высказываний можно строить новые, бо- 
лее сложные высказывания. 

Истинность или ложность получаемых таким обра- 
зом сложных высказываний, зависит от истинности 
или ложности исходных высказываний и соответству- 
ющей трактовки связок. 

Исчисление высказываний соединяет в себе сравни- 
тельную простоту с высокой содержательностью. 

2 . Логика предикатов первого порядка 

В отличие от логики высказываний, логика преди- 
катов первого порядка включает в себя термы, преди- 
каты, переменные, кванторы. Это позволяет использо- 
вать ее для описания и решения задач практически в 
любых областях знаний. 

Логика предикатов предназначена для описания ло- 
гических законов, справедливых для любой непустой 
области объектов с произвольно заданными на этих 
объектах предикатами. 

Элементарными компонентами логики предикатов 
являются предикатные символы, символы переменных, 
функциональные символы и символы констант. 
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Предикатный символ используется для представле- 
ния отношений в некоторой области. 

Запишем с помощью логики предикатов первого по- 
рядка следующее предложение: 

— Все инженеры должны проходить обучение на 
факультете повышения квалификации. 

Введем следующие обозначения: 

А(х) — X является инженером; 

В(х) — X должен проходить обучение на факульте- 
те повышения квалификации. 

Используем квантор всеобщности, обозначающий 
“для всех“, “для каждого“, “для любого“ и т.п. Запись 
(Ѵх) обозначает “для каждого х“,“для любого х“,“для 
всех х“. 

Тогда предложение будет иметь вид: 

( Ѵх) А(х) — > В(х) 

т.е. “для всех х таких, что х является инженером, х 
должен проходить обучение на ФПК“. 

Аналогично может быть записано предложение: 
“Некоторые инженеры часто ездят в командировки“. 

Введем обозначение: С(х) — х часто ездит в коман- 
дировки. Используем квантор существования, обозна- 
чающий “существует**, **для некоторых**. Запись ( Зх) 
обозначает **существует х**, **для некоторых х**. 

Тогда предложение будет иметь вид: 

(3 х) А(х) — > С(х) — 

что означает “существуют такие х, что если х являет- 
ся инженером, то х часто ездит в командировки**. 

В логике предикатов формулировка теорем и акси- 
ом развиваемой теории полностью записывается в виде 
формул, для чего употребляется особая символика, 
пользующаяся наряду с обычными математическими 
знаками и знаками для логических связок. 

Всем логическим средствам, с помощью которых те- 
оремы выводятся из аксиом, ставятся в соответствие 
правила вывода новых формул из уже выведенных. 
Эти правила формальны, т.е. таковы, что для провер- 
ки правильности их применений нет надобности вни- 
кать в смысл формул, к которым они применяются, и 
формулы, получаемой в результате; надо лишь убе- 
диться, что эти формулы построены из определенного 
набора знаков, расположенных соответствующим обра- 
зом. 

Доказательство теоремы отображается в выводе вы- 
ражающей ее формулы. 

3. Логический вывод 

Логический вывод можно рассматривать как после- 
довательность формул, в конце которой и находится 
формула, подлежащая выводу. Формула, используемая 
при выводе, либо выражает аксиому, либо получается 
из одной или нескольких предыдущих формул по од- 
ному из правил вывода. Формула считается выводи- 
мой, если может быть построен ее вывод. 

О доказуемости теорем в данной теории можно су- 
дить по выводимости выражающих их формул. 

Выяснение выводимости или невыводимости той 
или иной формулы есть задача, не требующая привле- 


чения далеко идущих абстракций, и решать эту задачу 
часто бывает возможно сравнительно элементарными 
методами. 

Логический вывод — это формальный вывод в ис- 
числении, содержащем логические правила и имею- 
щем в качестве основных выводимых объектов форму- 
лы. Под логическим выводом понимают содержатель- 
ное рассуждение, позволяющее от сформулированных 
аксиом и гипотез (допущений) переходить к новым 
утверждениям, логически вытекающим из исходных. 

При фиксированных аксиомах и правилах логичес- 
ких переходов говорят, что последовательность формул 
является выводом некоторой формулы А из гипотез 
А1, ..., Ап (п > 0), если каждый член последователь- 
ности либо является аксиомой или одной из гипотез, 
либо получается из предыдущих формул последова- 
тельности по одному из заданных правил. При этом 
формула А называется выводимой из А1, ..., Ап. 

Логическую программу можно использовать для по- 
иска любой информации, которая логически следует 
из заданного в программе описания некоторой пред- 
метной области. 

Для наглядного графического представления про- 
цесса логического вывода, а значит, и процесса реше- 
ния задач, описываемых и решаемых с применением 
логических средств, целесообразно использовать неко- 
торые понятия из теории графов. 

Теория графов — раздел конечной математики, 
особенностью которого является геометрический под- 
ход к изучению объектов. 

Граф задается множеством вершин (точек) и мно- 
жеством ребер (связей), соединяющих некоторые (или 
все) пары вершин. При этом пары вершин могут сое- 
диняться несколькими ребрами. 

Пример графа: Города Московской области и доро- 
ги, их соединяющие. 

Определенные пары вершин графа соединены реб- 
рами, и эти ребра направлены от одного элемента па- 
ры к другому. Граф, ребрам которого приписаны опре- 
деленные направления, называется направленным. 

Процесс логического вывода очень удобно изобра- 
жать в виде направленного графа. 

4. Стратегии поиска вершин графа 

При выполнении логического вывода используется 
стратегия поиска в глубину. При таком поиске верши- 
ны списка просматриваются в порядке убывания их 
глубины в дереве поиска. Более глубокие вершины по- 
мещаются на первое место в списке для просмотра. 
Вершины, расположенные на одинаковой глубине, 
упорядочиваются слева направо. 

Обычно при поиске используется вариант этой 
стратегии с возвращением. Возвращение проще реали- 
зуется и требует меньшего объема памяти. Стратегии 
с возвращением запоминают только один путь к 
целевой вершине; они не хранят полной записи 
процесса поиска, как это делают стратегии поиска на 
графе методом поиска в глубину. 
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Второй тип поиска называется поиском в ширину, 
поскольку просмотр вершин в дереве поиска происхо- 
дит внутри одного “уровня**, т.е. на одинаковой глуби- 
не. Поиск в ширину гарантирует нахождение кратчай- 
шего пути к целевой вершине при условии, что такой 
путь вообще существует. Если такого пути нет, то 
данный метод закончит работу неудачно в случае ко- 
нечных графов или никогда не закончит работу в слу- 
чае бесконечных графов [1-2, 5-6]. 

Многие программы, созданные в области искус- 
ственного интеллекта, в значительной степени основа- 
ны на методах формальных логических рассуждений. 
Когда задача определяется в ограниченной области, 
подобные методы обеспечивают мощные средства для 
усечения дерева поиска решения [5-6]. 

5. Метод резолюции 

Одним из наиболее популярных методов формаль- 
ных рассуждений является метод логического вывода, 
использующий опровержение отрицания, т.е. метод 
доказательства “от противного**, называемый методом 
резолюций. 

Чтобы применить метод резолюций, сначала надо 
представить доказываемое утверждение с помощью ло- 
гических формализмов исчисления предикатов. Затем 
следует отрицать доказываемое утверждение. 

Далее метод резолюций применяется к набору акси- 
ом, т.е. утверждений, заведомо справедливых в данной 
конкретной области или в данной ситуации, и к отри- 
цанию доказываемого утверждения. Если в результате 
мы приходим к противоречию, т.е. в результате логи- 
ческого вывода получаем пустой дизъюнкт, обозначае- 
мый О, то отрицание доказываемого утверждения до- 
лжно быть ложным, а само утверждение — истинным. 

При доказательстве по методу резолюций выполня- 
ется вычерчивание контрарных дизъюнктов. 

Метод резолюций обладает свойством полноты, т.е. 
если исходное утверждение истинно, то в любом слу- 
чае рано или поздно этот метод приводит к противоре- 
чию. Если же исходное утверждение ложно, то про- 
цесс вывода методом резолюций может оказаться бес- 
конечным. 

Однако метод резолюций имеет один существенный 
недостаток: число резолюций, выполняемых програм- 
мой, растет экспоненциально как функция сложности 
задачи. Программы, успешно применяющие метод ре- 
золюций для решения небольших задач, как правило, 
не способны справиться с более сложными реальными 
задачами. 

Лишь для малых задач можно создать программы, 
основанные только на методах формальных логичес- 
ких рассуждений. 

Сила логических методов заключается в том, что 
они позволяют представить объекты и связи между ни- 
ми в виде символов, которыми можно легко опериро- 
вать при помощи хорошо изученных методов, таких, 
как, например метод резолюций, осуществляя тем са- 
мым логические рассуждения. 


Слабость логических методов заключается в том же, 
в чем и их сила — с помощью строгих логических 
формализмов невозможно представить большинство 
реальных задач, оперирующих неполными и неточны- 
ми знаниями. 

6. Эвристические правила 

В настоящее время получили широкое распростра- 
нение экспертные системы, в большинстве из которых 
используются правила типа “если ... то ...“ (“если 
<условия> то <заключение>“), основанные на 
опыте экспертов, чьи знания заложены в экспертную 
систему. Такие правила называются эвристическими 
правилами, или эвристиками. 

Каждое такое правило может быть простым само по 
себе. Однако с помощью системы таких правил, ис- 
пользуемых как единое целое, оказывается возможным 
решать достаточно сложные задачи. 

Программы, основанные на эвристических прави- 
лах, в отличие от программ, основанных на формаль- 
но-логических методах, могут объяснять ход своих 
рассуждений в понятном для человека виде именно 
благодаря тому, что принимаемые программой реше- 
ния основаны на правилах, полученных от экспертов, 
а не на абстрактных правилах формальной логики. 

Формальные методы, даже если ими нельзя вос- 
пользоваться как основным средством рассуждения, 
могут сыграть полезную роль в управлении экспертны- 
ми системами. 

7. Комбинированные методы 

Ранние программы в области искусственного интел- 
лекта были основаны на каком-то одном подходе, ча- 
ще всего на формальных методах. Большое внимание 
было уделено созданию так называемого **универсаль- 
ного решателя задач**, который был бы способен ре- 
шать задачи в любой области знаний, основываясь на 
некоторых правилах формальной логики. 

Сейчас многими специалистами признана целесооб- 
разность использования нескольких различных подхо- 
дов [6]. 

Элементы знаний можно представить в программе 
разными способами. Каждый способ представления 
знаний может быть наиболее эффективен для одних 
операций и менее эффективен или вообще неэффек- 
тивен для других. 

Например, если программа должна эффективно 
отыскивать аналогии, то целесообразно представлять 
информацию о сравниваемых объектах в виде фрей- 
мов, состоящих из наборов ячеек, каждая из которых 
содержит значения атрибутов (свойств) объектов. Ког- 
да требуется найти аналогии между двумя объектами, 
представленными с помощью фреймов, то пустые 
ячейки одного фрейма заполняются значениями, взя- 
тыми из соответствующих ячеек другого. 

Для всех систем логического программирования как 
в узком, так и в широком смысле, характерно одно 
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общее обстоятельство; для исполнения программ ис- 
пользуются встроенные системы автоматического по- 
иска вывода (или автоматического доказательства те- 
орем). 

Схема работы таких систем практически одинакова: 
на вход программы подается запрос вида “Найти X 
такие» что имеет место А(Х) “ (где А — формула, 
X — набор переменных). Далее система, используя 
заложенные в нее методы поиска вывода, пытается 
найти ответ на такой запрос. Поэтому методы поиска 
вывода, встроенные в систему, определяются 
логической программой и видом запросов. 

8. Язык Пролог 

В Прологе, в качестве формул, используются хор- 
новские дизъюнкты. Большой класс практически важ- 
ных задач допускает естественное, вполне приемле- 
мое, описание с помощью этих формул. Кроме того, 
для них существует эффективный метод поиска вы- 
вода. 

Утверждения языка Пролог записываются в виде 
хорновских дизъюнктов, т.е. дизъюнктов, имеющих 
слева от знака “:-‘.з;Не более одного литерала (атомар- 
ной формулы или ее отрицания). 

Замечание, Здесь и далее используется синтаксис 
языка МПролог — одной из наиболее распространен- 
ных версий языка Пролог [2-4]. 

Утверждениям программы на языке Пролог соответ- 
ствуют хорновские дизъюнкты с заголовками, т.е. 
дизъюнкты вида: 

А:-В1,В2 Вп. 

а целевому утверждению — дизъюнкт без заголовка: 

:-В1,В2,...,Вп. 

В программе может быть только один целевой дизъ- 
юнкт, в противном случае задача будет неразрешима. 

Механизм поиска вывода, используемый в Прологе, 
берет свое начало от метода резолюций Робинсона. 
Формулами метода резолюций являются дизъюнкты, 
имеющие вид А 1 V ... V А. п , где А 1, ...» А п — ли- 
тералы. Атомы называются положительными литера- 
лами, а их отрицания — отрицательными. Порядок 
литералов в дизъюнкте несуществен. Используемые в 
Прологе формулы А и А 1А...АА п — > В эквива- 
лентны хорновским дизъюнктам А и ^ А IV ... V 
А пѴВ , где знак используется для обозначения 
отрицания. 

Метод резолюций, получив на вход набор дизъюнк- 
тов, пытается построить вывод пустого дизъюнкта [ ] . 


Текст утверждения языка Пролог “А:-В1,В2,...,Вп.“ 
может трактоваться двояко: 

- как логическое утверждение, что А истинно, если 
одновременно истинны утверждения В1,В2, ... , Вк. 

- либо как определение процедуры, утверждающее, 
что для того, чтобы выполнить процедуру А, надо 
выполнить все процедуры В1,В2,...,Вк. В сущности, 
обе интерпретации эквивалентны, что позволяет рас- 
сматривать язык Пролог и как алгоритмический язык 
программирования. Процедуры в правой части утвер- 
ждения выполняются слева направо в порядке их за- 
писи. 

Система Пролог основывается на процедуре доказа- 
тельства теорем методом резолюций для хорновских 
дизъюнктов. 

Система Пролог обладает встроенным механизмом 
логического вывода, благодаря чему, от пользователя 
требуется только описание своей задачи с помощью 
аппарата логики предикатов первого порядка, а поиск 
решения система берет на себя. Следует заметить, что 
для более эффективного использования заложенного в 
язык Пролог механизма логического вывода при реше- 
нии задачи, пользователь все-таки должен учитывать 
алгоритмические аспекты при описании своей задачи. 

Вопросы: 

1) Какой математический аппарат лежит в основе 
языка Пролог? 

2) Что такое хорновские дизъюнкты? 

3) Разрешима ли задача, не имеющая ни одного це- 
левого дизъюнкта? 

Ю. Тихонов 
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Фирма МіізиЬізЫ Еіесігіс выпустила компьютер-запис- 
ную книжку, содержащую в себе средства доступа к ин- 
(Іюрмационной системе МСА Зегѵісе ІпГоппаііоп Зухіет, 
функционирующей по радио. 

Эта машина является улучшенной версией нынешнего 
компьютера Маху Nо^е, к которому добавлены приемопе- 
редающее устройство, радиомодем, акустический соедини- 
тель и маленький принтер. 

Весь набор без проблем умещается в чемоданчик разме- 


ром 47x34x13 см. Он предназначен для очень деловых 
людей и стоит около 8800 долл. Аналогичная версия для 
хост-системы стоит 21500 долл. 

Общая стоимость системы, может быть, высока, но пе- 
редача данных в ней обходится дешевле, чем через обыч- 
ные автомобильные телефоны. Кроме того, мобильные те- 
лефоны в Японии работают в основном внутри городской 
черты,а система МСА покрывает большую часть страны. 

Ые\ѵ5Ьуіез Ые\^5 МеіУ^огк, 19 ^и^у, 1991 
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Денежки счет любят... 


Система Реаскігее СотрІе(е III 
фирмы РеасЬігее ЗоІЬѵаге 

Система РеасЫгее Сотріеіе III представляет собой 
интегрированную бухгалтерскую систему, как и 
ОасЕазу Ассоипііп^, предназначенную для малых и 
средних предприятий. Наличие мощных средств рабо- 
ты с базой данных и модульность этого пакета делают 
его также приемлемым для отделений больших корпо- 
раций, имеющих свои бухгалтерские службы. В прог- 
рамму встроены мощные средства генерации отчетов, 
ревизорские и прочие бухгалтерские средства и вклю- 
чает следующие модули: ‘Троссбух“ (Сепегаі Ьесі^ег), 
“Счета дебиторов** (Ассоипіз КесеіѵаЫе), **Счета кре- 
диторов** (Ассоипіз РауаЫе), **Фактурирование** 
(Іпѵоісіпв), **Управление запасами** (Іпѵепіогу), **3а- 
казы на поставку** (РигсНазе Огбег), **Калькуляция се- 
бестоимости заказа** (іоЬ Созііп^), **Основные средс- 
тва** (Ріхеб Аззеіз) и **3арплата** (РаугоИ). Дополни- 
тельный модуль РеасЫгее Оаіа Риегу III (РОр) обес- 
печивает генерацию отчетов. Несмотря на то, что сис- 
тема представляет собой набор обособленных модулей, 
используемые в них файлы данных — счета, постав- 
щики, потребители, продукция — общие и доступны 
всем модулям. 

Как РеасЫгее Сотріеіе III, так и РОр работают на 
компьютерах типа ІВМ РС и Р8/2 и совместимых с 
ними, требуют для своего функционирования не менее 
640 Кбайт оперативной памяти и 10 Мбайт памяти на 
жестком диске. Полностью установленная система, 
включая обучающий курс и справочную информацию, 
занимает около 8 Мбайт. 

Система позволяет вести независимый бухгалтерс- 
кий учет в подразделениях и дочерних компаниях, 
обеспечивая информацией бухгалтерию основной ком- 
пании за счет соответствия планов счетов, — иденти- 
фикация счетов отделов фирмы выполняется в послед- 
них двух разрядах кодов счетов. Работа каждого моду- 
ля характеризуется функциональной полнотой. Все 
операции пакета можно разбить на три группы: обра- 
ботка, генерация отчетов и поддержка. Функции обра- 
ботки позволяют выбрать и провести некоторую опера- 
цию. Функции генерации отчетов доступны в меню 


Окончание. Начало в Н9№7—8. 


каждого модуля в виде перечня возможных сгенериро- 
ванных отчетов. Функции поддержки позволяют изме- 
нять параметры настройки системы и добавлять запи- 
си в базу данных (например, новые виды продукции, 
новых поставщиков или покупателей). 

Процесс инсталляции системы сопровождается вво- 
дом данных контрольного примера. В обучающем кур- 
се показано, каким образом можно спроектировать и 
установить бухгалтерскую информацию собственной 
структуры, а также как выполнять различные опера- 
ции и генерировать отчеты. 

Собственно пользовательский интерфейс РеасЫгее 
Сотріеіе III выполнен в виде системы меню. Однако, 
в отличие от ОасЕазу Ассоипііп^, подменю главного 
меню представляются в виде всплывающих окон. Име- 
ются средства для просмотра справочной информации: 
пользователю не требуется запоминать все коды, ему 
достаточно нажать при выполнении некоторой опера- 
ции клавишу Р2, и в окне будет высвечен соответству- 
ющий файл базы данных. Как и в ОасЕазу Ассоипііп^, 
здесь имеются средства для дополнения и корректи- 
ровки базы данных. Навигация в меню РеасЫгее ти- 
пична для большинства программ — с помощью кур- 
сора или нажатием первой буквы названия соответст- 
вующей команды. Если пользователь должен ввести 
некоторый параметр, то, как правило, система выво- 
дит на экран все его возможные значения. 

Средства помощи контекстно-ориентированы, но, в 
отличие от большинства других программ, они не да- 
ют возможности просмотреть другую интересующую 
пользователя информацию за исключением относя- 
щейся к выполняемой в текущий момент функции. 

Модуль *Троссбух“ 

Модуль **Гроссбух** РеасЫгее Сотріеіе III работает 
в пакетном режиме. Модуль обрабатывает как непос- 
редственно вводимую пользователем информацию, так 
и информацию, поступающую от других модулей сис- 
темы. Пользователь также может задать повторяющи- 
еся операции и операции, выполняемые в конце фи- 
нансового периода, связанные с закрытием счетов и 
подготовкой гроссбуха к новому финансовому периоду. 
Модуль формирует итоги по каждому из счетов и рас- 
печатывает финансовые отчеты, которые могут, в 
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ДЕНЕЖКИ СЧЕТ ЛЮБЯТ... 


частности, содержать сравнение с аналогичными пока- 
зателями выделенного бюджета или показателями про- 
шлых лет. Модуль может генерировать отчеты о ре- 
зультатах хозяйственной деятельности подразделений. 

Модуль ‘Троссбух“ РеасЫгее автоматически распре- 
деляет полученные доходы по нескольким (до пяти) 
счетам, что упрощает подсчеты в случае наличия нес- 
кольких партнеров. Если в процессе настройки 
РеасЫгее Сотріеіе III указывается, что корпорация 
включает несколько дочерних фирм (число которых не 
ограничено), то “Гроссбух^ будет автоматически сво- 
дить итоги по всем подразделениям и генерировать 
сводный финансовый отчет. Модуль позволяет как вы- 
водить на экран, так и распечатывать финансовые от- 
четы. При выводе на печать баланса и финансового 
отчета они могут одновременно конкретизироваться по 
подразделениям, кроме того, в отчетах пользователь 
может задать колонтитулы. 

Модуль поддерживает трех- и четырехзначную ну- 
мерацию счетов, воспринимая при этом соответствен- 
но 5 или 6 цифр (в последних двух символах содер- 
жится код подразделения). Таким образом, пользова- 
тель может создать счета для 99 подразделений. Вмес- 
те с РеасЫгее поставляется план счетов, который 
пользователь может принять за основу и модифициро- 
вать, оставить неизменным или полностью отказаться 
от него, создав собственный. План счетов подразделе- 
ний должен точно соответствовать плану счетов ком- 
пании, в противном случае будут получены некоррект- 
ные результаты. 

В поставляемый план входит 76 счетов, хотя их 
число может достигать 26000. Пользователь может как 
модифицировать, так и запретить модификацию 
плана счетов. В процессе модификации РеасЫгее 
Сотріеіе III обеспечивает мощный контроль 
правильности вводимой информации. Например, в 
конце модификации плана счетов от пользователя 
можно потребовать как указания общего числа 
изменений, проведенных в плане счетов, так и 
контрольного числа, полученного на основе номеров 
счетов. Если эти значения не совпадут с 
вычисленными программой, то изменения вводиться 
не будут. Подобного рода строгий контроль вполне 
оправдан, поскольку ошибка в плане счетов приведет 
к сбою во всей дальнейшей работе системы. 

Пользователь может просматривать план счетов как 
в целом, так и в выбранном диапазоне и, если потре- 
буется, выводить на экран сальдо или содержимое сче- 
тов. На экран могут выводиться начальное сальдо, ко- 
нечное сальдо и текущие операции. 

Модуль “Гроссбух** имеет ряд средств, позволяющих 
адаптировать систему под конкретный вид деятельнос- 
ти. Пользователь может задать пароль, ограничиваю- 
щий ввод определенных типов операций, как то кор- 
ректировки счетов, начальных сальдо и т.п. Пользова- 
тель может указать продолжительность хранения ин- 
формации об операциях. РеасЫгее СотрІеІе III под- 
держивает 13 финансовых периодов — 12 месяцев, а 
13-й используется для проведения корректировок. 


В рамках интегрированной системы “Гроссбух** вос- 
принимает и обрабатывает информацию, поступаю- 
щую от модулей — **3арплата**, “Счета кредиторов**, 
“Счета дебиторов**, “Основные средства**. 

В регистре операций хранится список всех опера- 
ций, проводившихся в течение месяца. При выводе 
этого отчета на печать пользователь может отсортиро- 
вать записи по номеру счета или коду источника. 
Описание каждой операции включает список всех за- 
действованных в ней счетов, дату, сумму, источник и 
некоторые другие параметры. Этот отчет используется 
при проведении ежемесячной ревизии. 

При проверке сбалансированности гроссбуха поль- 
зователь после проводки всех операций за месяц и пе- 
редачи сводных журналов формирует промежуточный 
баланс. Балансовый отчет и отчет о результатах хо- 
зяйственной деятельности может формироваться либо 
в стандартной форме, либо в форме сравнения факти- 
ческих данных с выделенным бюджетом или финансо- 
выми показателями предыдущих лет. 

Модули “Счета дебиторов** 
и “Фактурирование** 

Модуль “Счета дебиторов** обрабатывает операции, 
связанные с покупателями, вычисляет величины нало- 
гов с продаж и платы за услуги, отслеживает неопла- 
ченные налоги и ведет базу данных на 14400 покупа- 
телей. Счета поставщиков поддерживаются как по 
принципу открытого требования (ореп Иет), так и пе- 
ренесенного сальдо (Ьаіапсе ІопѵагсІ). Кроме того, в 
системе могут обрабатываться и операции с непосто- 
янными покупателями. В систему заносится достаточ- 
но большое количество информации о каждом покупа- 
теле, включая идентификационный код, название, ад- 
рес, класс, тип счета, величину платы за услуги, код 
условий платежей и величину налога, при необходи- 
мости сообщение о наличии долга, предельную сумму 
кредита и адрес поставки. Средства поиска позволяют 
просматривать информацию как о покупателях, так и 
об их счетах и объемах операций, проходящих на этих 
счетах. 

Модуль “Фактурирование** использует те же данные 
о покупателях, что и “Счета дебиторов**, и позволяет 
готовить счета-фактуры одновременно с проводкой 
операций на счетах. Модуль позволяет кодировать ус- 
ловия платежей и задавать до трех различных видов 
платы за услуги, которые могут вычисляться как про- 
цент от среднего еженедельного или конечного сальдо 
на счету покупателя. Модуль одновременно с форми- 
рованием счетов-фактур вносит требуемые изменения 
в модули **У правление запасами** и “Счета дебито- 
ров**. 

Модуль генерирует два вида счетов-фактур — на 
продукцию и услуги. В фактурах на продукцию указы- 
ваются дата поставки, идентификатор и описание из- 
делия, цена за единицу и количество. Фактуры на ус- 
луги имеют несколько более свободную форму, допус- 
кая включение в нее полного описания предоставлен- 
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НОЙ услуги. Каждая запись в счете-фактуре не должна 
превышать 160 символов. С помощью поля *'класс по- 
купателя“ можно указать, что выписка счета-фактуры 
должна осуществляться регулярно' с некоторой перио- 
дичностью. 

Наряду с фактурами модуль генерирует отчеты о 
работе с покупателями. Отчет может включать сооб- 
щение длиной до 75 символов, а также сообщение о 
необходимости срочного погашения долга. В отчет мо- 
гут включаться операции, проводившиеся с покупате- 
лем по всем месяцам или только за текущий месяц, 
при этом для всего предшествующего финансового пе- 
риода формируется лишь значение сальдо. 

В совокупности оба модуля выполняют операции по 
проводке и распечатке счетов-фактур, выдаче креди- 
тов, вычислению платы за обслуживание, проводке 
платежей, а также проводке счетов-фактур в гроссбухе 
и модуле “Управление запасами**. 

Средства просмотра файлов позволяют просматри- 
вать и модифицировать списки покупателей и продук- 
ции. Перед акцептованием любой из операций по же- 
ланию пользователя производится проверка на превы- 
шение предельной суммы покупки товара в кредит. 

Система позволяет генерировать ряд отчетов, в том 
числе отчеты о налогах с оборота для налоговых уп- 
равлений, отчеты о работе с покупателями, регистр 
всех операций по приходу средств за определенный 
период, регистр непроведенных счетов-фактур, 

регистр невыполненных заказов и отчет о 

задолженности покупателей. 

При работе модулей совместно с модулем “Управле- 
ние запасами** проводка платежей и возврата товаров 
автоматически изменяет величину запасов на складе. 
При работе модуля “Фактурирование** в сочетании с 
управлением запасами можно генерировать отчеты о 
недостающих, но требующихся товарах, а также отче- 
ты о прибыльности различных видов товаров. Модуль 
“Счета дебиторов** также работает совместно с моду- 
лем “Калькуляция заказа** и проводит операции, свя- 
занные с выполнением заказов. Наконец, все опера- 
ции, проводимые в модуле, отражаются в гроссбухе. 

Модуль “Счета кредиторов** 

Модуль “Счета кредиторов** регистрирует информа- 
цию о поставщиках, счетах-фактурах и кредитах; вы- 
числяет потребность в наличности и генерирует отче- 
ты о предоставлявшихся ранее скидках. Модуль прово- 
дит операции по закупке и оплате товаров и генериру- 
ет платежные поручения на оплату товара. В базе 
данных поставщиков может храниться до 14400 запи- 
сей, кроме того, можно работать и со случайными пос- 
тавщиками. Максимальная величина платежей не дол- 
жна превышать 99.999.999 долларов 99 центов. 

Модуль позволяет проводить фактурирование, кре- 
дитные операции и платежи. При выписке фактур на 
оплату модуль может руководствоваться заданным 
пользователем критерием, в частности, сроком пога- 
шения кредитного обязательства. После этого система 


будет автоматически генерировать платежные поруче- 
ния, если пользователь в явном виде не укажет про- 
тивное. Кроме того, перед печатью платежных поруче- 
ний система выводит список всех подлежащих оплате 
счетов-фактур. 

Система поддерживает до девяти регистров платеж- 
ных документов банковских счетов и может автомати- 
чески выписывать платежные поручения в заданном 
пользователем формате. На корешке платежного пору- 
чения указываются дата, номер, сумма, наименование 
поставщика и адрес. Само платежное поручение со- 
держит наименование и адрес поставщика, сумму про- 
писью (естественно, на английском), защищенное по- 
ле с указанием суммы в долларах и центах, дату и но- 
мер платежного поручения. 

Функции фактурирования позволяют осуществлять 
фиксированные платежи, как то проценты по ссудам 
или арендную плату, при этом пользователь должен 
указать номера месяцев, в которые производятся вып- 
латы. Модуль автоматически формирует счета, указы- 
вая дату выплаты, сумму, дату, с которой начинается 
предоставление скидки, процент этой скидки. Такого 
рода выплаты могут осуществляться ежемесячно, раз в 
два месяца, раз в квартал, раз в полгода или раз в год. 
Как и в случае обыкновенных счетов-фактур, пользо- 
ватель может перевести эти счета на любой из девяти 
банковских счетов, а сумму распределить между восе- 
мью счетами гроссбуха. 

При просмотре файла поставщиков можно запро- 
сить информацию об их текущей деятельности, про- 
сроченных кредитах и неоплаченных счетах-фактурах, 
платежах и существующих ценах. В процессе провод- 
ки транзакций в специально открываемом окне можно 
просмотреть файлы поставщиков и продукции. 

При генерации отчетов можно получить список от- 
крытых счетов-фактур, информацию о потребности в 
наличных деньгах на оплату товаров, приобретенных в 
кредит, по датам, регистр операций, в который вклю- 
чены все операции, проведенные в модуле “Счета кре- 
диторов**, ежемесячный регистр платежных поруче- 
ний, список всех периодических платежей и список 
поставщиков. Модуль также позволяет проводить опе- 
рации по выплате заработной платы сотрудникам, не 
работающим постоянно в фирме. 

Модуль “Счета кредиторов** записывает информа- 
цию о проведенных операциях в гроссбух. Он также 
интегрирован с модулем **3аказы на поставку**, кото- 
рый формирует заказы на поставку продукции постав- 
щиками. Наконец, модуль работает совместно и с мо- 
дулем “Калькуляция себестоимости заказа** при про- 
водке операций, связанных с приобретением материа- 
лов для выполнения заказов. 

Модуль “Заказы на поставку** 

Модуль “Заказы на поставку** формирует заказы 
поставщикам на поставку продукции и отслеживает 
полные и частичные поставки. Кроме того, модуль 
взаимодействует с модулем “Управление запасами**, 
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автоматически изменяя величину запаса при поставке. 
Модуль использует ту же базу поставщиков, что и 
“Счета кредиторов**; пользователи также могут про- 
сматривать и модифицировать списки поставщиков. 
То же относится и к базе данных запасов. 

Заказы на поставку создаются с использованием 
стандартной информации, в них можно добавлять до- 
полнительные данные. Допускается заказывать мате- 
риалы, не регистрируемые в модуле “Управление за- 
пасами**, а также изменять уже сформированные зака- 
зы. При частичных поставках заказ остается открытым 
вплоть до полной поставки или его закрытия. Одно- 
типные изделия в поставке могут иметь разную цену, 
в этом случае каждому экземпляру присваивается уни- 
кальный номер и цена устанавливается по мере по- 
ступления продукции от поставщика. 

Модуль позволяет печатать заказы на поставку из- 
менения к заказам, и указания о прекращении постав- 
ки и генерировать списки планируемых поставок. Кро- 
ме того, в отдельный отчет помещаются невыполнен- 
ные заказы с указанием поставщика и состояния пос- 
тавки. Наконец, модуль генерирует список открытых 
заказов. 

Рассматриваемый модуль является связующим меж- 
ду **Счетами кредиторов** и “Управлением запасами**. 
Он модифицирует счета кредиторов и использует базу 
данных поставщиков. С другой стороны, при поступ- 
лении заказа этот модуль изменяет величину запасов 
и формирует справки для формирования последующих 
заказов. 

Модуль “Управление запасами" 

Модуль **Управление запасами* может хранить ин- 
формацию о 19500 наименованиях изделий и имеет 
средства, позволяющие учитывать вхождение комплек- 
тующих элементов при сборке. Каждое изделие имеет 
15-значный код, в котором указывается код типа изде- 
лия, код подразделения и номер экземпляра изделия. 
Кроме того, система отслеживает объем и цену пос- 
тавки, объем полученной продукции и возврат, а 
также количество изделий, находящихся в 
незавершенном производстве (при сборке). Поль- 
зователь может включать в базу дополнительные 
описания для всех видов продукции, регистрируемых в 
модуле. Модуль хранит информацию о запасах на 
текущий и предыдущий месяцы или финансовые 
периоды, либо всю информацию текущего года. 

Для определения себестоимости продукции может 
использоваться пять различных методов. Большинство 
операций, связанных с управлением запасами, могут 
проводиться из модулей “Фактурирование** и “Заказы 
на закупку**. Основной задачей этого модуля являются 
в основном функции, связанные с ценообразованием, 
ведением информации о незавершенном производстве 
и выполнением операций по формированию отчетных 
документов. 

Изменение величины себестоимости может произво- 
диться как автоматически, так и вручную. Пользова- 


тель может указать либо абсолютное значение, либо 
прирост в процентах. 

Модуль позволяет генерировать ряд отчетов, в том 
числе список цен на хранящуюся продукцию с указа- 
нием названия, информации о поставщике, 
количества и трех уровней цен; отчет о состоянии 
запасов с указанием остатков на конец каждого 
месяца; отчеты по подразделениям; отчет по 
калькуляции себестоимости; отчеты о комплектации, 
содержащие список наименований компонентов, 

входящих в готовое изделие с указанием их 

количества; отчет о хранении запасов, позволяющий 
определять место физического расположения 

продукции на складах, и итоговый отчет, формиру- 

емый на конец месяца или года. 

Модуль также генерирует регистр всех проводив- 
шихся операций, связанных с управлением запасами, 
включая и те, которые были сгенерированы из других 
модулей. 

Модуль “Зарплата" 

Модуль рассчитывает величину зарплаты, налогов и 
прочих удержаний и позволяет учитывать основные 
отпуска и отпуска по болезни. Максимальная числен- 
ность, на которую может рассчитываться зарплата, 
составляет 3900 человек. Модуль также позволяет ге- 
нерировать квитанции на оплату и проводить соответ- 
ствующие операции, а также генерировать налоговые 
отчеты. Выплата зарплаты может проводиться раз в 
неделю, две недели, полмесяца или месяц. Модуль 
также имеет встроенную таблицу налогов, взимаемых 
в США по всем 50 штатам. 

Пользователи могут создать таблицу для кассира, в 
которой указываются данные и зарплата каждого сот- 
рудника. Также имеется программа для обработки ис- 
ключительных ситуаций. 

Модуль поддерживает несколько способов начисле- 
ния зарплаты, включая любое сочетание окладной, по- 
часовой зарплаты, разовых вознаграждений и комисси- 
онных; вычисление доплат к зарплате за сверхурочную 
работу, работу во вторую и третью смены; выплату 
зарплаты в любом сочетании с недельным, двухне- 
дельным, полумесячным и месячным циклом; все виды 
налогов, принятых в США; три дополнительных вида 
доходов и шесть дополнительных видов скидок; авто- 
матический учет дополнительных отпусков за сверх- 
урочно отработанное время. 

Модуль проводит все операции в гроссбух, с разне- 
сением окладов по трем разным журналам и зарплаты 
рабочих-почасовиков по десяти различным счетам. 

Модуль ведет базу данных сотрудников, в которую 
включаются код, имя и адрес сотрудника, величина 
доходов и другая информация. 

После ввода величины зарплаты система вычисляет 
сумму к выдаче и генерирует чек на получение денег, 
а также отчеты о величине зарплаты и удержаний. 

Модуль взаимодействует с модулями “Гроссбух** при 
проводке операций начисления зарплаты и “Калькуля- 
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ция себестоимости заказа**, который позволяет автома- 
тически определять зарплату за выполнение опреде- 
ленных работ по заказам. 

Модуль ^Калькуляция себестоимости заказа** 

Модуль **Калькуляция себестоимости заказа** позво- 
ляет определять затраты на выполнение заказа. В чис- 
ло затрат включаются расходы на материалы, оплату 
рабочей силы и накладные расходы. Модуль также вы- 
числяет величину доходов от выполнения заказа. До- 
пускается разбивать выполнение заказа на этапы и 
вводить информацию о завершении этапа и его опла- 
те, сроках начала выполнения заказа, проценте вы- 
полнения, а также сопоставлять предварительные и 
фактические величины затрат. В зависимости от 
величины фактической себестоимости допускается 
изменение цены. 

После начала выполнения заказа он заносится в 
файл заказов, где содержится информация об этапе, 
на котором он находится, необходимых для его вы- 
полнения производственных мощностях, материальных 
и трудовых затратах. Код затрат включает информа- 
цию о количестве рабочих часов, необходимых для вы- 
полнения заказа, и код материальных ресурсов, база 
данных которых хранится в модуле **Управление запа- 
сами**. Модуль также использует файл покупателей, 
поддерживаемый модулем **Счета дебиторов**, и взаи- 
модействует с модулем ** Зарплата**, внося изменения в 
зарплату сотрудников, выполняющих заказы. 

В процессе работы пользователь может получить 
справку о состоянии выполнения заказов, где отража- 
ются наименование заказчика, количество изменений 
к заказу, процент выполнения, исходная цена, цена с 
учетом корректировок и себестоимость заказа. Модуль 
позволяет получать отчеты, содержащие данные о ве- 
личине рентабельности заказа и себестоимости по 
статьям калькуляции. 

Модуль **Основные средства** 

Модуль **Основные средства** ведет информацию о 
производственных и конторских зданиях, сооружени- 
ях, оборудовании и позволяет рассчитывать величину 
износа и амортизации, а также хранить в базе данных 
до 12000 записей, добавлять и удалять (списывать) 
новые записи, а также изменять величину износа. 

Модуль поддерживает 13 различных методов опре- 
деления износа, а также может переходить при его 
определении от одного метода к другому, например, из 
соображений снижения налогов. 

Модуль позволяет генерировать ряд отчетов, в том 
числе содержащих информацию о приобретении, лик- 
видации, износе основных средств; графики износа ос- 
новных средств за неделю, месяц, квартал, полугодие 
и год. 

При выполнении операций модуля **Основные сред- 
ства** автоматически модифицируются соответствую- 
щие журналы гроссбуха. 


Дополнительные возможности 

Все модули РеасНТгее Сотріеіе III обеспечивают 
защиту от несанкционированного доступа. При досту- 
пе к данным имеется два уровня парольной защиты. 
Первый уровень позволяет также устанавливать сами 
пароли. 

Система, кроме того, имеет полуавтоматические 
средства восстановления данных. При изменении фай- 
лов она напоминает пользователю о необходимости 
создания резервных копий. Ответ **уез** на подсказку 
приведет к записи на диск измененных файлов. 

Генерация отчетов 

Каждый модуль РеасНТгее Сошріеіе поддерживает 
достаточное число отчетов, начиная с распечаток соот- 
ветствующих файлов, и кончая сложными бухгалтерс- 
кими отчетами по специфике модуля. Пользователь 
имеет определенную степень свободы в выборе форма- 
та выводимого на печать отчета, например, платежно- 
го поручения или заказа на закупку. 

Наконец, к РеасНТгее Сотріеіе поставляется допол- 
нительный модуль РеасНТгее Оаіа Риегу III (РОР), 
обеспечивающий доступ пользователю к базе данных и 
генерацию отчетов. С помощью РОР пользователь мо- 
жет извлекать значения полей из любых файлов базы 
данных, формировать списки, графики и нестандарт- 
ные отчеты. Модуль обеспечивает экспорт в форматы 
Ьоіиз 1-2-3 и БутрНопу, МісгозоП МиИірІап и Ѵізісаіс, 
АзНІоп-ТаІе бВАБЕ, а также в виде файлов А8С1І и 
ОІР. 

Модуль имеет меню-ориентированный интерфейс и 
позволяет отбирать и обрабатывать поля информации, 
получая промежуточные и окончательные итоги, вы- 
полнять над полями арифметические и логические 
операции, сортировать их и получать средние значе- 
ния. 

В целом программа РеасНТгее Сотріеіе III выпол- 
няет все основные бухгалтерские процедуры и может 
полностью удовлетворить потребности малых и сред- 
них предприятий. Безусловным достоинством системы 
является наличие модуля **Основные средства**, а так- 
же мощных возможностей работы с базой данных и 
генерации отчетов. Наконец, его цена на фоне доста- 
точно сильных возможностей выглядит чрезвычайно 
низкой — всего 200 долларов. 

Однако наряду с достоинствами, программа имеет 
такие недостатки, как отсутствие сетевых средств и 
обучающей программы. 

М.Михайлов 

По материалам: 

Раиікпег ТесЬпісаІ Керогіз оп Місгосотриіегз апсі 
ЗоІЬѵаге; 

ОаІаРго Керогіз оп Місгосотриіегз. 
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Между прочим... 


ДВЕ ОПЕРАЦИОННЫХ 
СИСТЕМЫ НА ДИСКЕ 

Некоторые виды программного обеспечения и спе- 
цифические платы требуют использования конкретной 
версии операционной системы (обычно М8-В08 4.0). 
В то же время ваше программное обеспечение может 
быть оптимизировано под использование той версии 
008, которая установлена. Что делать в таком случае? 

Самый простой и надежный путь — записать в 
различные каталоги (или на разные диски) разные 
версии операционных систем. Но здесь нужно учиты- 
вать, что М8-008 умеет грузиться только с дисков А: 
и С:. Поэтому основную систему имеет смысл устано- 
вить на диск С:, а вторую загружать с гибкого диска. 

При этом нужно иметь отдельный каталог для каж- 
дой системы и при загрузке подключать лишь один из 
них — это необходимо для того, чтобы все утилиты 
работали как следует. 

Не забудьте в файле А11Т0ЕХЕС.ВАТ описать пе- 
ременную С0М8РЕС так, чтобы система искала ко- 
мандный процессор (СОММАЫО.СОМ) на диске С:, а 
не на А:, например так (если командный процессор 
находится в корневом каталоге): 


8ЕТ С0М8РЕС = С:\СОМ\Ш^П.СОМ 

В противном случае вам придется постоянно менять 
гибкие диски, вставляя системный взамен рабочего. 

Этот метод замедляет загрузку, но с этим вполне 
можно мириться. 

Более хитрый метод заключается в использовании 
специальных пакетов для разметки жесткого диска. 
Обычно они позволяют выбрать раздел диска, с кото- 
рого будет производиться загрузка. Однако этот путь 
можно рекомендовать только наиболее опытным и ак- 
куратным пользователям, ведь одно неверное движе- 
ние — и ваш жесткий диск прикажет долго жить, 
притом восстановить его будет не слишком просто. 

Так что лучше пользоваться более простым мето- 
дом, описанным выше. 

КАК ИСПОЛЬЗОВАТЬ ДИСКИ ТИПОВ, 
ОТСУТСТВУЮЩИХ в ПЗУ ВІ08 

Нередко случается, что купленный винчестер не со- 
ответствует ни одному из типов накопителей, присут- 
ствующих в постоянном запоминающем устройстве, 
содержащем ВІ08. При этом возникают всяческие 
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проблемы — в лучшем случае просто не используется 
часть диска, в худшем — не удается отформатировать 
его вообще. 

Эту проблему можно обойти как минимум тремя 
путями. Первый состоит в использовании утилиты 
''наращивания^' ВІ08, содержащей информацию об 
очень многих типах накопителей самых разных изго- 
товителей и записывающий ее в КМОП-ОЗУ вашего 
компьютера (то есть туда, где обычно хранится ин- 
формация о его конфигурации). Таких утилит доволь- 
но много, поэтому используйте ту, которая будет со- 
держать описание винчестера той марки, которая вас 
интересует. В качестве примеров таких утилит можно 
привести Ѵіеаіиге Оеіих фирмы СоШеп Воіѵ Зузіетз, 
СаШогпіа Теп Раск фирмы (ІаШогпіа Зоі^ѵаге Ргобисі. 

Второй путь — использование специализированных 
пакетов форматирования дисков Оізк Мапа^ег и 
ЗреебЗіог. Оба включают в себя длинный список нако- 
пителей самых различных фирм и, кроме того, позво- 
ляют вручную ввести параметры накопителя, если он 
не соответствует ни одному из предлагаемых типов. В 
сущности, этот режим аналогичен использованию опи- 
санных выше утилит — при этом точно так же сведе- 
ния о диске записываются в подпитываемое ОЗУ. 

Третий путь проще двух первых, но не всегда он 
является наилучшим. Можно просто сменить ВІ08 на 
более свежую версию. Для этого нужно знать его наз- 
вание и фирму-изготовителя (чаще всего используется 
ВІ08 одной из трех марок: РНоепіх, А\ѵагсІ или АМІ). 
Узнать ее элементарно — как правило, при загрузке 
системы первым сообщением является сообщение 
именно о марке ВІ08'а. Если вы не увидите его, при- 
дется снять крышку компьютера и прочитать наклейку 
на микросхеме с ВІ08. Обратите внимание на номер 
его версии и дату создания. Имея эти сведения, можно 
поискать более новую версию ВІ08, но перед покуп- 
кой стоит выяснить, есть ли в ней интересующий вас 
тип накопителя. 

Первый метод самый дешевый — обычно такая ути- 
лита стоит совсем недорого, второй — самый дорогой, 
но он дает вам дополнительные возможности по подго- 
товке накопителей на жестких дисках к работе. Заме- 
на ВІ08 занимает промежуточное положение по цене, 
но может преподнести несколько приятных сюрпри- 
зов — например, исчезнет ошибка, с которой вы боро- 
лись все время работы на данном компьютере, или до- 
бавится поддержка более современных устройств. 

ОСВОБОЖДЕНИЕ МЕСТА 
ПОД РИСУНКИ ПРИ РАБОТЕ 
С МІСК080РТ \ѴОІШ 

Если вы готовите какую-либо публикацию (напри- 
мер, документацию или бюллетень), которая будет 
размножаться с помощью ротапринта или копироваль- 
ной машины, вам может понадобиться вставить в ори- 
гинал-макет фотографии или что-нибудь, нарисован- 
ное от руки. Конечно, можно отсканировать изображе- 
ние и вверстать его на компьютере. Но для того, что- 


бы потом получить приличное качество фотографии, 
качества обычного лазерного принтера будет недоста- 
точно. Поэтому-то столь живуч дедовский метод "нож- 
ниц и клея". 

Итак, чтобы оставить место под рисунок, следует 
воспользоваться опцией Рогтаі рОзИіоп. 

Прежде всего нужно создать новый параграф (аб- 
зац) — то-есть просто нажать на Епіег. Далее с помо- 
щью этой команды нужно сформатировать данный аб- 
зац требуемым образом. При этом вы можете задать 
размер оставляемого чистым "окошка", его положение 
на листе, можете привязать его к конкретному месту 
на полосе. 

Процедура заключается в следующем. Создав абзац, 
поместите на него курсор и перейдите в меню Рогтаі 
рОзИіоп. Измерьте ширину вашей иллюстрации и вне- 
сите ее в графу Ігате дѵісШі. Ширину полей вокруг 
картинки внесите в графу ёізіапсе Ігот 1^x1. Положе- 
ние окошка на полосе определяется графами Ногізопіаі 


Оригинальная локальная сеть! 

”0»ісеІАМ” 

Качество и надежность! 
Доступная цена. 

Отсутствие сервера. 
Подключение без вскрытия компютера. 
С^овместимость (N0, МиШ-Е<Ш, Сііррег,...). 
Поддержка сетевых принтеров. 
Гарантийное обслуживание. 

До 20 абонентов, скорость до 38 кБод. 
Длина линии до 1200 м, двойная изоляция. 


Распределенная система, 
автоматизации и сбора данных. 
СКАТ 

Автоматизация большинства технологий 
Высокая надежность. 

Быстрое восстановление. 

Низкая стоимость тиражирования. 
Гибкая архитектура: 

Объект О микропроцессорные контрол- 
леры О сеть О ІВМ-РС. 


Позвоните нам сегодня/ 

Москва: (095) 288т97-43і23 (9,00 - 22,00). 
Ленинград: (812) 5 15-27-4 1 (9,00 - 22.00), 
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?гате розіііоп и ѵегисаі Ггате розіііоп, а также допол- 
няющими их графами геіаііѵе Іо. Вы можете выбрать 
некоторое стандартное положение — например, в 
центре полосы (обе графы описаны как сепіегесі). 
Кроме того, можно задать положение в абсолютных 
единицах — то есть отступы слева и сверху. Стан- 
дартным является положение абзаца Іп Упе — в том 
месте, где он был вставлен в текст. В этом случае он 
привязывается к конкретному месту в тексте. 

Несколько слов о значении графы геіабѵе Іо. Что 
такое соіитп, думаю, понятно всем. Маг^іпз обознача- 
ет, что все расстояния будут считаться не от края лис- 
та, а от полей, описанных в Рогтаі Оіѵізіоп Маг^іпз. 
Выбор режима ра^е позволяет сместить блок за преде- 
лы текстовой полосы. Если абзац, к тому же, обведен 
рамкой, можно получить весьма интересный эффект. 
Здесь можно также использовать абсолютные величи- 
ны сдвигов, очень точно определяя положение блока 
на полосе. 

Ну и последняя операция — установка высоты бло- 
ка. Для этого сохраните все изменения, внесенные в 
пункт Рогтаі рОзШоп, и перейдите к пункту Рогтаі 
Рага^гарН. Здесь задайте нужную высоту блока, изме- 
нив интерлиньяж абзаца (Ипе зразіп^). Замечу, что 
тут можно использовать любые принятые в М5 >ѴогсІ 
единицы длины, но обязательно нужно указать, какие 
единицы вы имеете в виду (по умолчанию считается, 
что вы задали размер в линиях — что-то около 
4.236 мм). 

Место под иллюстрацию можно отбить линейками, 
либо заключить в рамку. Делается это с помощью 
пункта меню Рогтаі Вогбег. 

НЕКОРРЕКТНАЯ ОБРАБОТКА 
ФУНКЦИИ АСНОІСЕО 
БИБЛИОТЕКИ ЕXТЕN^•^IВ 
КОМПИЛЯТОРА 
СЫРРЕК ЗиММЕК'87 

Всем хороша функция АСНОІСЕО компилятора 
СИррег 5иттег'87 фирмы Мапіискеі. Однако при на- 
писании контекстного НЕЬРа для АРМа, где эта фун- 
кция широко применялась, я столкнулся с некоторой 
некорректностью в ее работе, заключающейся в том, 
что после вызова клавишей Р1 процедуры подсказки 
из меню, созданного этой функцией, передвижения по 
альтернативам меню вызывают искажения экрана, а 
именно: справа от того места, где была выведена под- 
сказка, появляется текст альтернативы выбора меню 
(этот текст должен был быть выведен там, где стоял 
подкрашенный выделенным (елНапсеб) фоном маркер 
(рготрО. 

Ниже приведен текст демонстрационной програм- 
мы. Откомпилируйте, слинкуйте и стартуйте этот при- 
мер. При появлении меню нажмите клавишу Р1 (поя- 
вится подсказка), затем любую другую клавишу и сно- 
ва “погуляйте** по меню. Вы увидите, что текущая 
альтернатива восстановится не на своем месте. Види- 
мо, функция АСНОІСЕО не запоминает положение 


курсора при нажатии клавиши Р1 и после отработки 
процедуры НЕІР выводит на экран свое текущее сооб- 
щение уже не на то место, куда следовало бы. 

Способ борьбы с этим, который я считаю недостой- 
ным проколом фирмы МапІискеІ, состоит в следую- 
щем. При входе в процедуру НЕЬР запомните текущее 
положение курсора, а при выходе — восстановите. Со- 
ответствующие операторы демонстрационного примера 
закрыты комментариями, откройте их (строки 12,13 и 
20) и АСНОІСЕО не исказит картинку после выхода 
пользователя из НЕЕРа. 

Кстати, в документации фирмы утверждается, что 
при вызове процедуры НЕЕР, переменная САЕЕ_РК.С 
содержит имя вызывающей процедуры. Однако в на- 
шем случае эта переменная будет содержать не строку 
символов “ОЕМО**, а строку **АСНОІСЕ()** (предла- 
гаю убедиться в этом самостоятельно), что несколько 
усложняет написание процедуры справки в части бло- 
кировки рекурсивных вызовов. Можно предположить, 
что АСНОІСЕО написана на языке 6ВА5Е (Сііррег), 
хотя и в этом случае стоило бы позаботиться о кор- 
ректном содержимом переменной САЕЕ_РК.С. 

Текст пакетного файла трансляции, редактирования 
и выполнения: 

сИррег (Іешо 

Шпк (Іето,(1ето,с1ето,с1іррег ехіеікі 

бето 

Р.8. Вышеописанные неточности исправлены в 
СИррег 5.0. 

Файл бето.рг^: 
сіесіаге ш [5] 

@ 0,0 сіеаг Іо 24,79 
аЛП (ш, альтернатива ) 
аеі СОІОГ іо ѵ//Ь 
@ 1,1,7,16 Ьох $расе(9) 

@ 1,3 8ау ВЫБЕРИТЕ ## 

@ 7,4 аау Т1 — НЕЕР' 
асНоісе(2,2,6,15,т) 

@ 0,0 сіеаг Іо 24,79 

♦ 

ргосебиге НЕЕР 
♦♦♦♦ к = соІ() 

♦♦♦♦ 1 = гои^О 

ааѵе асгееп іо асг 
ОІСІСОІОГ = аеісоІогО 
аеі СОІОГ іо п/Ь^ 

@ 13,18 аау 'Нажмите любую клавишу и поіуляйте по меню' 
іпкеу(О) 

5еісо1ог(о1с1со1ог) 

♦♦♦• @ і,к зау " 

гезіоге зсгееп Ггот зсг 

И.Вязаничев 

В.Макаренков 

По материалам: 

РС/СотриІіп^, ЕАМ Тітез 
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■ Сегодня еще можно включиться в 
национальна и в мировую систему 
электронной почты, став 
пользователем сети РЕІСОМ ** 

■ Демос/* обеспечит подключение к 
сети, а так же, при необходимости, 
поставит оборудование: компьютер, 
телефонный модем и программное 
обеспечение 



Оборудование фирмы НР 

Компьютеры, лазерные принтеры, плотеры и 
другая периферия фирмы Нет^Іеіѣ-Раскаг(1 
реализуется со скидкой. При поідгпке лазерного 
принтера ^а8е^^еі III за валюту - скидка до 31%!!! 
Гарантийное обслуживание 3 года 

Модемы МКР-5 

снижены цены 

24(Ю/48(Ю Ьрз встроенные и внеппше, 
адаптированные к отечественным линиям, 
эффективно работающие в почтовой сети. 
Коррекция ошибок, компрессия данных, Науез 
совместимые, аттестованы Минсвязи СХХЗР. 
Гарантийное обслуживание 1 год. 

Компьютерные сети 

снижены цены 

Локальные и глобальные. Работы по установке и наладке. 
Документация на русском языке по ОС N 040 !! КеіІУаге. 
Подключение локальной сети к электронной почте КБЬСОМ. 

Різдательские системы 

Шрифтовые кассеты кириллицы для лазерных принтеров 
Салоп, НР Ьааег ^еі. Загружаемые шрифты кириллицы для 
лазерных принтеров Салоп, ЬавегЛеі и моделей, совместимых 
с ними. Микропрограммы кириллицы: прошивка ПЗУ 
принтеров, адаптеров мониторов и пр. 

Оригинальное 8оГѢ)Ѵаге 

ОС ДЕМОС 2.2 для СМ-1700, СМ-4, Электроника-85/79. 
Прикладные программы для систем, совместимых с ОС 
ЦШХ. Пакеты русификации систем 8СО Хеліх, М8 77іл(1очг8. 

Системы Автоматизации 

Платы (ШМ РС АТ/ХТ) АЦП-ЦАП. 

Блок АЦП: 20 разрядов, связь по К8-232 (заказ). 
Платы релейных коммзгтаторов и цифровых каналов. 
Платы цифровых каналов (до 24 вх/вых.). 

Платы интерфейса канала общего пользования. 
Платы ЦАП. 

Платы аналоговых усилителей. 

Контроллер крейта КАМАК для ШМ РС АТ/ХТ. 


ДЕМОС/*: 113035 Москва, Овчинниковская наб. дом 6/1, телефон: 231-21-29, 231-63-95; 
Рах: 233-5016; Б-таі1: іпГо@Ьд.<1етов.8и 


** Электронная почта сети Веісош создана Демос/* и ИВЦ ИАЭ им. Кзфчатова, и зарегистри- 
рована Междзгнародным центром в Стенфорде (США). По вопросам заключения договоров на 
подключехше к сети Кеісот обращаться по телефонам Демоса/* и телефону ІІВЦ: 196-72-50. 
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НОВОСТИ 



новости 


Два директора фирмы 8ип Місгозузіетз посетили 
Москву с очень интересным визитом. Они, видимо, яв- 
ляются одними из последних представителей фирм, 
предлагающих советским компьютерным командам 
участвовать в совместных научных разработках. 

Дэйвид Дитзел, директор по перспективным разра- 
боткам, и Джордж Тэйлор, директор по эксперимен- 
тальным архитектурам, прочитали лекцию на факуль- 
тете вычислительной математики и кибернетики МГУ, 
осветив технические возможности 8рагс-технологии. 

Фирма 8ип Місгозузіетз, вероятно, будет сотрудни- 
чать с лучшими разработчиками ИС в СССР — это 
команда из Института точной механики и вычисли- 
тельной техники. 

Компания 8ип хочет влить свежую кровь в свои ин- 
женерные команды и находит, что специалисты из 
ИТМиВТ своим умом дошли до ряда моментов, ис- 
пользованных в создании Зрагс-процессоров. 

8ип имеет в СССР эксклюзивного дистрибьютора — 
фирму Просистем (как отмечают некоторые эксперты, 
это не самый лучший выбор). 


— продажа оборудования в США шла особенно плохо; 
в Европе — хорошо; 

— объем продаж программного обеспечения возрос на 
13%; его сумма составила 2.35 миллиарда долларов; 

— объем услуг возрос 18,9%; 

— лизинг возрос на 16,2%. 

ІВМ Сотриіег Тойау, 24 Арг.-7 Мау, 1991 

Фирма ІВМ иЗВК открыла свой первый учебный 
центр в Ленинграде. Этот центр, который будет функ- 
ционировать при помощи имеющихся в Ленинграде 
пяти бизнес-партнеров ІВМ, предназначен для обуче- 
ния пользователей работе с ІВМ-компьютерами. 

Фирма переехала с Покровского бульвара в большее 
помещение на улице Веснина. За новое помещение 
Моссовет получает 500 тысяч долларов в год. В старом 
помещении открывается еще один учебный центр — 
для обучения продавцов ІВМ-техники. 

МеУѵзЬуіез МеШ)гк, И Іиіу 1991 


МвУѵзЪуіез Ме\ѵ8 Меімюгк^ 15 /ипе, 1991 

Фирма ІВМ закончила первый квартал 1991 года со 
следующими финансовыми показателями: 

— объем продаж аппаратного обеспечения снизился 
на 17%; 

— прибыли от продажи сетевого оборудования упали 
на 48%; 


СП “Параграф** начало продажу русификатора ба- 
зы данных Рагаёох. Об этом было объявлено на фору- 
ме мира ПК в Москве. 

Русификатор, который поставляется в виде отдель- 
ной программы, прилагаемой к фирменной коробке с 
последней (3.5) версией Рагабох, полностью убирает 
английские буквы с экрана монитора. Все элементы 
меню, подсказки весьма аккуратно переведены на рус- 
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ский язык. Кроме того, с русификатором можно зада- 
вать русские имена полей в базе данных и произво- 
дить сортировки по алфавиту — оригинальный про- 
дукт этого делать с русскими буквами не мог. 

Русификация, произведенная Параграфом самосто- 
ятельно, была полностью одобрена фирмой Вогіапб. 

Это уже не первая версия русификатора. Первая 
была создана более года назад. Эти работы ведутся 
группой программистов под руководством Павла Зе- 
линского. 

Вместе с коробкой Рагасіох и полностью переведен- 
ной русской документацией все удовольствие стоит 
9900 рублей. Хотите купить — звоните в Параграф 
(095) 200-25-66. 

МешЪуіе$ Меш МеШ>гк, 12 Іиіу 1991 

Как изменились ограничения КОКОМ на 
экспорт в Советский Союз?? 

Можно ввозить любые персональные компьютеры с 
процессором 80386. 80486 все еще находится в списке 
товаров, требующих получения лицензии на ввоз. ІВМ 
8у8Іет/36, МісгоѴАХ 3 и другие подобные машины 
теперь также можно купить без лицензии. 

Вместо старого ограничения на винчестеры — 
150 Мбайт емкости и скорость передачи 10 Мбит/с — 
осталось лишь одно — скорость передачи информации 
от привода не должна превосходить 25 Мбит/с. 

Любое программное обеспечение к компьютерам, 
которые можно легально ввозить, лицензирования не 
требует. 

По-прежнему под запретом — локальные сети на 
более чем 200 пользователей, оборудование для воло- 
конно-оптических линий связи, программы, обеспечи- 
вающие гибкую маршрутизацию сообщений в компью- 
терных сетях. 

Ме\\^8Ъуіе8 Ме\ѵ8 Меімюгк, 14 Іиіу 1991 

Палата представителей конгресса США при- 
няла законопроект о перераспределении частот. 
Палата представителей проголосовала за законопро- 
ект, согласно которому полоса электромагнитного спе- 
ктра шириной 200 МГц, ранее использовавшаяся воен- 
ными, передается для использования в гражданских 
целях. Но будущее законопроекта остается туманным 
из-за споров с Белым домом о способе распределения 
этих новых частот. Белый дом хочет, чтобы право 
пользования этими частотами было вынесено на аук- 
цион. Конгресс же считает, что их надо передать бес- 
платно после слушаний, в ходе которых определится. 


какие предложения наилучшим образом отвечают об- 
щественным интересам. 

Теіериііп^ Ноіііпе/ ЫетВуШ 

Фирма 6ТЕ создает совместное предприятие 
с Советским Союзом. Фирма СТЕ создаст 240 те- 
лефонных линий, которые свяжут Москву с остальным 
миром с помощью микроволновой и спутниковой свя- 
зи. Проект будет выполняться вместе с находящейся в 
США фирмой Бап-Ргапсізсо — Мозсодѵ Теіерогі и со- 
ветским Министерством связи. По заявлению СТЕ, 
СП Боѵіпіеі начнет предоставлять услуги в ноябре за 
твердую валюту для гостиниц и деловых центров в 
Москве. В настоящее время тем, кто хочет осущест- 
вить звонок, приходится несколько часов ждать, пока 
линия не освободится. Московские специалисты счита- 
ют, однако, что новое предприятие вряд ли разрушит 
монополию СП Сотзіаг, в настоящее время единст- 
венного предприятия, предоставляющего услуги по ус- 
тановлению быстрой международной телефонной свя- 
зи местным деловым людям. На данный момент Ми- 
нистерство связи утвердило создание более 150 сов- 
местных предприятий. 

Теіерийп^ Нойте / МетВу1е8 

Цифровой переносной телефон: японская но- 
винка. МЕС объявила о создании 195-граммового 
цифрового сотового переносного телефона. Он немного 
больше аналогичного изделия “Моѵа“ фирмы МТТ, но 
меньше, чем Місгоіас фирмы Моіогоіа. В нем исполь- 
зуются схемы фирмы МТТ, которая предоставляет 
свою технологию также фирмам Ри]И8и, МаІзизЬіІа, 
МіІзиЬізНі и Моіогоіа. Ожидается, что работа телефон-, 
ной переносной цифровой сотовой службы начнется в 
Токио осенью 1992 года. В отличие от ситуации в 
США, цифровые телефоны в Японии будут несовмес- 
тимы с аналоговыми. 

Теіериііп^ НоШпе/ МешВу1б8 

ТозНіЬа выпускает новые изделия в Японии и 
США. Фирма ТозНіЬа выпустила на рынок продукт, 
который она называет самой быстрой в мире перенос- 
ной рабочей станцией (класс Іаріор). 8РАВС 
ЬТ/А81000 использует К.І$С процессор фирмы 5ип 
Місгозузіетз и работает со скоростью 17.5 миллионов 
операций в секунду (МІР8) — прошлогодняя модель 
работала со скоростью 13.4 МІР8. А81000 имеет 
встроенный жесткий диск на 329 Мбайт, вместо 
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которого можно установить диск емкостью 3 Гбайта. 

Фирма 8ип будет продавать эти станции под своим 
именем. Среди покупателей — Ри]іІ 5 и, Окі, Іілізуз 
іарап и Ри^і Хегох. Цена — 1.78 миллионов йен 
(13000 долларов). 

В США ТозЫЬа выпустила в продажу модем 
Т240/Х. Он работает на скорости 9,600 бод для пере- 
носных РС на сотовой и проводной телефонной сети. 
Он совместим со старыми компьютерами, начиная с 
Т1200. 

ТозЫЬа ІІ8А также выпустила три новых компьюте- 
ра — записных книжки (поІеЬоокз) серии 2000. Они 
весят 6.9 фунта (2.9 кг.), и в двух из них 

используется процессор Іпіеі 803868Х. 

Федеральная торговая комиссия (РТС) сочла японс- 
кие компании виновными в поставке плоских экранов 
на американский рынок по демпинговым ценам и мо- 
жет поднять таможенные тарифы на дисплеи на жид- 
ких кристаллах до 63%. Американские компьютерные 
компании выступают против этих тарифов, заявляя, 
что они увеличат стоимость их продукции, а это за- 
ставит их уступить рынок японским конкурентам. 

Теіерийп^ НоШпе / Мем^Вуіез 

Неполадки в телефонной сети США. Ошибки в 
программном обеспечении неизбежны, и это надо учи- 
тывать. Для создания цифровой телефонной сети нуж- 
но заменить все аппаратные соединения на програм- 
мные. А в программном обеспечении по самой его 
природе обязательно будут ошибки. 

Такие ошибки могут дорого обойтись, как выяснила 
компания 08С Соттипісаііопз. Похоже, что выпущен- 
ная в апреле очередная версия программного обеспече- 
ния для их 8і^па1 Тгапз^ег Роіпіз (Точек передачи сиг- 
нала) не прошла тщательной проверки. Программное 
обеспечение отказало, и 8ТР прекратили работу, когда 
произошел перепад в подаче электроэнергии в Балти- 
море. Это повторилось в Лос-Анджелесе, потом в Пит- 
тсбурге. Каждый раз при этом миллионы пользовате- 
лей оставались без телефонной связи. 

8ТР являются ключевыми компонентами цифровой 
сети. В сети І80Ы все сигналы, определяющие марш- 
руты звонков, отделяются от самих звонков и проходят 
через 8ТР. Если 8ТР прекращают работу, становится 
невозможно позвонить. А 8ТР работают на програм- 
мном обеспечении. 

Обнаруженная проблема будет решена с помощью 
дополнительной программы, которая будет действовать 


как предохранитель. Перепады электроэнергии не бу- 
дут выводить из строя все устройство целиком, а толь- 
ко его часть. И эти сбои, в свою очередь, не приведут 
к отключению коммутаторов, потом коммутационных 
станций, а затем целых городов. 

Но что произойдет в следующий раз? Большинство 
представителей компаний согласны с тем, что нужны 
дублирующие пути про запас. Если одна дорога зава- 
лена, вы идете по другой. Большие компании подстра- 
хуются, построив собственные сети или используя так 
называемые **обходные*‘ компании. Но, если верить 
Федеральной комиссии по связи (РСС), остальным 
может и не повезти. 

Есть и другая проблема, специфическая для фирмы 
08С. Существует вероятность того, что фирма понесет 
юридическую ответственность с тяжелыми финансовы- 
ми последствиями. Вся компания в настоящее время 
поставлена под удар. Если бы такая неисправность 
случилась в станциях фирм МогІНегп Теіесош, АТ&Т 
или Егісззоп, такой угрозы бы не существовало. 

Теіерийпі Ноіііпе / МетВуІез 

АТ&Т не сочувствует ранам, нанесенным ха- 
керами фирме Мі1$иЬі$Ьі. МНзиЬізНі не получила 
поддержки ни от АТ&Т, ни от Федеральной комиссии 
по связи США по вопросу возбуждения дела, направ- 
ленного на возвращение фирме денег, украденных ха- 
керами (компьютерными взломщиками) через РВХ 
(местную АТС фирмы) в Нью-Йорке. МіІзиЬізЫ тре- 
бовала от АТ&Т возмещения 10.4 миллионов долларов 
плюс оплаты судебных издержек за звонки, сделанные 
компьютерными преступниками, начиная с 1988 года 
через 8уз1ет 85 — системы обмена частными сообще- 
ниями в филиале фирмы (РВХ). 

Наилучшие РВХ такие, как 8уз1епі 85, позволяют 
всем работникам компании звонить друг другу — даже 
с других континентов — с помощью 6-значного допол- 
нительного кода, что делает эти системы уязвимыми. 
Хакеры звонили по бесплатному номеру, использовав- 
шемуся для набора этого шестизначного дополнитель- 
ного кода, а затем разговаривали со всем миром бес- 
платно. МіІзиЫзНі, однако, не хочет брать на себя от- 
ветственность, заявляя, что РВХ произведена АТ&Т и, 
стало быть, та во всем виновата. 

Недавно в РСС поступила жалоба компании 
СНагі^ѵауз, которая пыталась возложить на АТ&Т оп- 
лату междугородных звонков в похожей ситуации. Но 
РСС в мае не только отвергла жадобу, но вынесла ре- 
шение, что “владелец РВХ обладает лучшими возмож- 
ностями по поддержанию безопасности системы, и он 


КомпьютерПресс 9'91 




новости 


77 


несет ответствен ность*\ если безопасность нарушена. 
АТ&Т заюила, что компании известно о проблемах с 
безопасностью, и у нее есть необходимое программное 
обеспечение, позволяющее от них избавиться. Но за 
использованием РВХ должно вестись регулярное наб- 
людение. И если вы не выполняете рекомендованные 
действия, то вам может крупно не повезти. 

Теіерийпі НоШпе/ МешВуіез 

Стандарту по безопасности брошен вызов, 
США сдерживают принятие стандарта по безопаснос- 
ти для передачи компьютерных сообщений, настаивая 
на том, что Агентство Национальной Безопасности 
должно всегда иметь возможность расшифровать сооб- 
щения, используя стандарт. Агентство борется за тре- 
бование использовать алгоритм, названный ЕЮашаІ, 
запатентованный в США, в то время как в компьютер- 
ной индустрии более популярна схема шифрации 
К.5А. И8А негодует, но правительство заявило, что 
ЕІСатаІ позволит сэкономить деньги. Похоже, что 
единственный коммерческий продукт, основанный на 
схеме шифрации ЕІСатаІ, — это программа ЗесгеІ 
А^епсу фирмы Іпіогтаііоп ЗесигИу из Деерфилда, Ил- 
линойс. 

Теіерийпі НоИіпе / МешВуІез 

Смоленск: местные власти поднимают теле- 
фонные тарифы. Власти Смоленска решили поднять 
тарифы на телефонные разговоры по собственной 
инициативе. Такое происходит в Советском Союзе 
впервые. Ранее на услуги телефонной связи тарифы 
устанавливались правительством из Центра. Плата за 
установку телефона увеличилась на 50%, фиксиро- 
ванная месячная плата за пользование удвоилась. Для 
предприятий тарифы увеличились в 10 раз. *Тадио 
России" подвергло решение критике. 

Теіериііпі НоШпе / ЫешВуіез 

8ирегТаЫеІ с вводом с клавиатуры/электрон- 
ным карандашом. Фирма Тизк из Флориды сообщи- 
ла, что ею разработан компьютер-планшет А11-Теггаіп 
ЗирегТаЫеІ, позволяющий осуществлять ввод как с по- 
мощью электронного карандаша, так и с клавиатуры. 
Он будет, начиная с IV квартала этого года, соперни- 
чать с производимым фирмой ЫСК компьютером 
3125, использующим электронный карандаш. Кроме 
клавиатуры, компьютер, по заявлению компании, от- 
личается упрочненным дизайном, который может 


выдержать удар пули, но весит всего 6 фунтов 
(2.5 кг.) против 3.9 фунта (1.6 кг.), которые весит 
компьютер ЫСК. Оба компьютера могут работать с 
МЗ-008, 03/2, РепАррз, Репроіпі, >Ѵіп(Іо^ 3.0 и 
Опіх. Компьютер фирмы Тизк будет стоить 6000 дол- 
ларов, на 1,2000 долларов больше, чем компьютер 
МСК. 

Теіерийп^ НоШпе / МешВуіез 

СОРІА INТЕКNАТIОNА^ анонсировала прог- 
рамму Сге(Ш Сагб Рег Рах, которая позволит бюро с 
факсовыми службами получить номер кредитной кар- 
точки, зарегистрировать покупку в банковском учреж- 
дении и переслать платежный документ. Компания за- 
явила, что вся процедура занимает обычно около ми- 
нуты. 

Теіерийпі НоШпе / МешВуіез 

МІТ8ЦВІ8НІ объявила о создании опытной версии 
новой факс-машины, которая пересылает страницу 
информации по телефонным линиям за 5 секунд, в 
три раза быстрее действующих моделей. В ней исполь- 
зуются сжатие данных и более скоростные модемы, и 
она могла бы стоить намного меньше, чем существую- 
щие факс-машины серии Огоир IV. 

ФИРМА КОНМ из Японии утроит производство 
дисплеев на жидких кристаллах, используемых в ком- 
пьютерах класса Іаріор. Фирма предсказывает, что в 
скором времени они будут использоваться в системах 
навигации автомобилей. 

Теіерийп^ Нойіпе / МешВуІез 

СП Интермикро стало первым официальным пред- 
ставителем фирмы Арріе в Советском Союзе. 

Созданное в 1988 году совместное советско-австрий- 
ское предприятие будет выполнять работы по локали- 
зации программного обеспечения для Макинтоша и 
созданию сети дилеров по стране. 

Сделку финансирует финансовая группа Ргозузіет, 
владеющая 60 % уставного капитала СП Интермикро. 

По утверхсдению ряда экспертов, это уже не первая 
попытка фирмы Арріе выйти на советский рынок. 

В СССР, по заявлению представителей компании, 
будут свободно продаваться все модели Макинтоша. 
Возможно, в будущем новые модели компьютеров на 
процессоре Моіогоіа 68040 потребуют получения ли- 
цензии на ввоз. 
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Фирма ВОХЕ8 предлагает коробки для дискет 
по цене, не превышающей стоимость одной дискеты с 
доставкой любого их количества (вплоть до 1 шт) 
непосредственно потребителю за наличный и 
безналичный расчет. Заявки, с указанием количества, 
следует присылать на открытках ( письма 
вскрываться не будут) по адресу: 

115230 Москва-230, а/я 1, ’Ъохев”. 


Фирма ВОХЕ8 готова закупать у 
изготовителей на выгодных условиях пластмассовые 
коробки для дискет большими партиями, а также 
оказать некоторую техническую помощь в их 
изготовлении своим партнерам. Предложения по 
сотрудничеству присылайте по адресу: 

109544 Москва-544, а/я 000, "Вохе5*\ 


Электронные словари 


системы СіпдѴо. 

85 тыс. слов 

|в англо— русско-немецких словарях,] 
и 3.5 Кб в оперативной памяти! 

Расспросите нас подробнее о системе Ып^Ѵо по телефонам: 

(095) 264-83-18 и (095)264-22-77 (ассоциация "НОФКОН”). 
107078 Москва, а/я 212, фирма БИТ. 



Э«Т; 




Поставки компьютеров первым советским покупате- 
лям начнутся в середине сентября этого года. Пример- 
но в ноябре появится полностью переведенная на рус- 
ский язык документация к компьютеру. Эту работу за- 
канчивает группа сотрудников МГУ, в которую входят 
не только программисты, но и, что очень важно, фи- 
лологи и лингвисты. Тестовая версия операционной 
системы, по заявлению Интермикро, существует уже и 
сейчас. 

Компьютеры будут продаваться по ценам, близким 
к европейским. 

Технический директор СП Интермикро Анатолий 
Карачинский сказал также, что они ожидают потока 
русифицированных программ для Макинтоша в тече- 
ние одного-полутора лет. 

Уже есть русские версии редактора текстов, и изда- 
тельского пакета ^иа^к Хргезз 3.1. Версия Ѵепіига 


РиЫізНег появится в течение полугода. 

Как сообщил в начале месяца представи- 
тель фирмы МісгозоП Дейл Кристиансен, 
их фирма, которая выпускает и программы 
для Мака, еще не рассматривала вопрос об 
их локализации. “Мы сможем быстро сде- 
лать это сразу после того, как получим от 
Арріе версию русской операционной сис- 
темы “. 

Ме\\^8Ъуіе8 Пеш Меіуюгк, 
23 Іиіу, 1991 

Фирма ЗЬагр начинает поставки в СССР 
нескольких новых типов портативных ком- 
пьютеров. Теперь кроме РС-6220 можно 
купить еще три типа машин класса поіе- 
Ьоок и лаптоп с цветным монитором. 

РС-6240 — почти аналогична РС-6220. 
Отличие заключается в емкости винчесте- 
ра: если у 6220 она составляет 20 Мбайт, 
то у 6240 — 40. Остальный параметры ос- 
тались теми же: процессор 80С286, такто- 
вая частота 12/7.16/6 МГц, ОЗУ 1 Мбайт 
с возможностью расширения до 3 Мбайт, 
гнездо для сопроцессора 80С287 (12 МГц), 
время доступа к диску 23 мс, монитор фир- 
мы ЗНагр соответствует стандарту ѴСА и 
обеспечивает разрешение 640x480 точек и 
16 оттенков серого. Вес компьютера 2 кг, 
толщина всего 34 мм, время работы от ба- 
тарей несколько уменьшилось — 1.7 ч. 
против 2 ч. РС-6240, как и 6220, снабжен 
операционной системой и пакетом Гар- 
Упк, размещенными в ПЗУ. 

РС-6521 и РС-6541 открывают новую серию поіе- 
Ьоок-компьютеров РС-6500. В ней использован тот же 
монитор, что и в серии РС-6200. Этот компьютер так- 
же построен на базе процессора 80С286 
12/7.16/6 МГц с возможностью использования сопро- 
цессора. ОЗУ емкостью 1 Мбайт расширяется до 
4 Мбайт с помощью модулей в 1 и 2 Мбайта. Жесткий 
диск имеет емкость 20 Мбайт (РС-6521) и 40 Мбайт 
(РС-6541) при времени доступа 23 мс. В отличие от 
6200, машины серии 6500 оборудованы встроенным 
накопителем на гибких дисках 3.5“ 1 .44 Мбайта, но и 
весят больше — 2.9 кг. Внешне эта машина имеет 
много общего с ТгаѵеІМаІе 3000. 

И, наконец, очередной шедевр фирмы, которая сей- 
час является лидером в области разработки и произ- 
водства жидкокристаллических мониторов — лаптоп 
РС-8501 с цветным экраном. Это мощный и вполне 
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транспортабельный компьютер, построенный на про- 
цессоре 80386ОХ с тактовой частотой 20/8 МГц. 
Можно использовать сопроцессор 80387ОХ с тактовой 
20 МГц. 

Монитор соответствует стандарту ѴСА, обеспечивая 
воспроизведение 16 цветов при разрешении 
640x480 точек и 256 цветов при разрешении 320x200 
или 360x480 точек. Дисплей с диагональю 10.4 дюйма 
создан с использованием технологии ТРТ — тон- 
копленочных транзисторов, которая позволяет 
получить изображение с почти фотографическим 
качеством. Компьютер имеет ряд необычных 
дополнительных режимов работы, повышающих 
качество воспроизведения цветных изображений. Эта 
машина (как, впрочим и другие портативные компью- 


теры ЗЬагр с цветным экраном) разрабатывалась в 
основном для проведения презентаций. Поэтому 
вполне логичным является то, что изображение может 
дублироваться на внешнем мониторе, в том числе и на 
проекционном. 

Жесткий диск имеет емкость 100 Мбайт, на- 
копитель для гибких дисков 3.5 дюйма 1.44 Мбайта 
также не забыт. Оперативная память — 2 Мбайта. 
Возможно расширение до 10 Мбайт. 

Весит эта машина 6.9 кг, питается только от сети. 
Она довольно громоздка (318x399x94 мм) и 
напоминает первые лаптопы, но это — совершенно 
другой уровень технологии. Дополнительно фирма 
предлагает внешний накопитель для 5.25-дюймовых 
дисков, такой же, как и для РС-6500. 


На этой странице помещен бланк заказа на сборник «КомпьютерПресс» 

Вы можете его вырезать и, заполнив, отправить в конверте по адресу: 

113093, Москва, а/я 37. 

Подписка на 1992 г. принимается до 31 января 1992 г. Число экземпляров — без ограничений. 

Вы можете выписать журнал на полгода или на год. Стоимость годовой подписки на 
«КомпьютерПресс» — 57 рублей 60 копеек. 

Деньги следует перечислить на расчетный счет агентства “КомпьютерПресс^. 

Банковские реквизиты: 

получатель: Автобанк (для зачисления на счет №345708) 
расчетный счет получателя: №161202 

банк получателя: ЦОУ при Госбанке СССР. МФО №299112. 

Копию платежного документа необходимо приложить к бланку заказа. 

Без одновременной оплаты подписной стоимости заказ не принимается. Издания агентства 
“КомпьютерПресс** наложенным платежом не высылаются. 


ЗАКАЗ 

От кого 

Адрес 

(ПОЧТОВЫЙ ИНДЕКС УКАЗЫВАТЬ ОБЯЗАТЕЛЬНО) 

Прошу оформить подписку на 1992 год 


Подписная плата в сумме 


перечислена 

платежным поручением (почтовым переводом) № 
(Копия платежного документа прилагается) 

от 

199 г. 
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Советско-американское предприятие ”Соваминко” 
Рекламно-издательское агентство ** КомпьютерПресс** 

Принимает заказы на журнал ** КомпьютерПресс** и 
отправку наложенным платежом. 


Заказ высылается по адресу: 191186, Ленинград, Невский проспект, 28, 

Магазин № 1 ”Дом книги” 


От кого 


(почтовый индекс указывать обязательно) 


Номера выпусков . Количество экземпляров 
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Советско-американское предприятие ** Соваминко*' 
Рекламно-издательское агентство ** КомпьютерПресс*' 


Принимает заказы на журнал ** КомпьютерПресс** и 
е/ производит отправку наложенным платежом. 


ч 

ч 

ч 

ч 


Заказ высылается по адресу: 630076, Новосибирск, Красный проспект, 60 
Магазин № 7 "Техническая книга” 

Телефон для справок: 20 05-09 


От кого 


Адрес 


(почтовый индекс з^азывать обязательно) 


Номера выпусков 


Количество экземпляров 




ЗА РУБЛИ, ЗА ДОЛЛАРЫ 

ПОСТАВКА СО СКЛАДОВ 
В МОСКВЕ 

Высокоэффективный лазерный 
принтер НемІеП РаскагсІ 
каэегиеі ІІІР, технические 
характеристики которого 
приближаются к 
характеристикам широко 
известного принтера 
^а8ег^е( III, а цена 
значительно ниже. 

Кроме того, мы поставляем 
разнообразную вычислительную 
технику, периферийное 
оборудование, принтеры, 
плоттеры, сканеры и расходные 
материалы производства фирмы 
НеШіі Раскагб. 

Продажа через дилерскую сеть 
фирмы АКѴ8 Напйеіе А.О. 

тел. (095)230-5612 
факс. (095)230-2182 

Малое предприятие 
•’КиМ” 
тел. (095)220-3185 
факс. (095)230-2182 


ПРЕДЛАГАЕТ 
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